

دانشگاه صنعتی امیرکبیر (پلی تکنیک تهران) دانشکده مهندسی کامپیوتر

پایاننامه کارشناسی

پیادهسازی ارتباط باس CAN FD بین میکروکنترلر و FPGA مبتنی بر پروتکل CANOpen

> نگارش محمد چمن مطلق

استاد راهنما دکتر محمدمهدی همایونپور

بهمن ۱۴۰۰

# چکیده

ارتباطات بین سیستمهای نفهته، همواره موضوع بسیار مهمی بوده است و تلاشهای فراوانی در جهت طراحی ارتباطات استاندارد وجود دارد. برخی از این استانداردها صرفا یک ارتباط فیزیکی را مشخصی می کنند، برخی یک پروتکل سطح بالا هستند و برخی نیز شامل هر دو قسم می شوند. در این میان می توان به باسهایی نظیر SPI ،I2C و CAN اشاره نمود. باس CAN یک باس استاندارد شناخته شده در صنایع خودروسازی، اتوماسیون، صنایع هوایی، فضایی و دیگر صنایع مرتبط است و ویرایشهای مختلفی از این باس توسعه یافته است. CAN FD یک ویرایش خاص از باس CAN میباشد که توانایی افزایش نرخ انتقال بدون تغییر لایه فیزیکی CAN را فراهم میآورد. با توجه به نوین بودن CAN FD، تلاشهای کمتری در راستای پیادهسازی و استفاده از این باس صورت گرفته است. هدف نهایی این پروژه، پیادهسازی یک ارتباط دو طرفه با بهرهوری همزمان از باسهای CAN و CAN FD به کمک یک میکروکنترلر و یک FPGA است. بنابراین در راستای انجام این پروژه، دو نوع پیادهسازی (میکروکنترلر و FPGA) توسعه یافته است که ارتباطی بین FPGA و میکروکنترلر از طریق CAN ایجاد کرده و در ادامه ارتباطی مبتنی بر باس CAN FD توسط IP-Core این باس در پیادهسازی شده است. این پیادهسازی در قالب دو پیکربندی متفاوت انجام شدهاند و در نهایت پس از برقراری ارتباط، صحت انتقال مورد بررسی قرار گرفته و ارتباطات موجود از جنبههای مختلفی نظیر میزان ترافیک، نرخ بیت، تحمل نویز و درصد خطا مورد ارزیابی قرار گرفتهاند. همچنین، تلاش شده است که انتقال داده میان قطعات مبتنی بر پروتکل CANOpen صورت گیرد.

# واژههای کلیدی:

واسط ارتباطی، باس داده، سیستم نهفته، میکروکنترلر، FPGA

#### صفحه

# فهرست مطالب

| 1          | فصل اول:  مقدمهفصل اول:  مقدمه              |
|------------|---------------------------------------------|
| ۲          | ١-١- تعريف مساله                            |
| ۴          | ۱-۲- ضرورت و اهداف پروژه                    |
|            | ٦-٦- ساختار گزارش                           |
|            | فصل دوم: باس CAN                            |
|            | <br>۲-۲ - ویژگیهای فنی                      |
| ٩          | ١-١-٢- لايه فيزيكي                          |
|            | ۲-۱-۲ لایه لینک داده                        |
| ١۵         | ۲-۲- مقایسه باس CAN با باسهای دیگر          |
| ١٧         | ۳-۲- ویرایشهای باس CAN                      |
|            | TTCAN -Y-٣-١                                |
| ١٨         |                                             |
|            | ۴-۲- پروتکلهای لایههای بالاتر سازگار با CAN |
| ۲۵         | ۱-۴-۱- پروتکل OBD2                          |
|            | ۲-۴-۲ پروتکل SAE J1939                      |
| ۲۵         | ۲-۴-۳- پروتکل CANOpen                       |
| Y9         | فصل سوم: طراحی و پیادهسازی ارتباطات         |
| ٣٠         | ۳-۱- اهداف و ساختار کلی                     |
| ٣٢         | ٣-٢- قطعات مورد استفاده                     |
| ٣٢         | ۱-۲-۳- برد Arduino Due                      |
|            | ۳-۲-۲- برد Ava3S400                         |
| ٣۴         | ۳-۲-۳- برد فرستنده-گیرنده TJA1050           |
| ٣۶         | ۳-۳- نرمافزارهای مورد استفاده               |
| ٣٧         | ۳-۴- کتابخانههای مورد استفاده               |
| ٣٧         | ۱-۴-۳ کتابخانه Due CAN                      |
| ۴٠         | liteCAN IP Core -۲-۴-۳                      |
| <b>F</b> 7 | CTU CAN FD IP Core -٣-۴-٣                   |
| 44         | ۳-۸- برادوریانی انجام شده                   |

| ۴۸       ۲-۵-۳         فصل چهارم: ارزیابی ارتباطات       ۵۴         ۵۲       ۹-۱-۴         ۵۷       ۳-۴         ۵۸       ۹-۳-۳         فصل پنجم: نتیجهگیری و پیشنهادات       ۶۲         منابع و مراجع       ۹۰         پیوستها       ۷۰ | <b>*</b> * | ۳-۵-۳- ساختار سختافزاری         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------------------------|
| ۵۴                                                                                                                                                                                                                                      | ۴۸         | ٣-۵-۲- ساختار نرمافزاری         |
| ۵۷ - ۲- میزان بهرهوری از منابع         ۵۸ - ۳- ارزیابی و مقاومت باس         فصل پنجم: نتیجه گیری و پیشنهادات         منابع و مراجع                                                                                                      | ۵۳         | فصل چهارم: ارزیابی ار تباطات    |
| ۵۸ ــــــــــــــــــــــــــــــــــــ                                                                                                                                                                                                 | ۵۴         | 1-۴- صحت عملكرد                 |
| فصل پنجم: نتیجه گیری و پیشنهادات                                                                                                                                                                                                        | ۵٧         | ۴-۲- میزان بهرهوری از منابع     |
| منابع و مراجع                                                                                                                                                                                                                           | ۵۸         | ۴–۳– ارزیابی و مقاومت باس       |
| C. 7 7 C.                                                                                                                                                                                                                               | 97         | فصل پنجم: نتیجهگیری و پیشنهادات |
| ييوستها                                                                                                                                                                                                                                 | 99         | منابع و مراجع                   |
| <b>=</b>                                                                                                                                                                                                                                | ٧٠         | پيوستها                         |

#### صفحه

# فهرست اشكال

| ۴   | شکل ۱-۱: نمودار بلوکی اجزاء پروژه                                                     |
|-----|---------------------------------------------------------------------------------------|
| ۹   | شکل ۲-۱: مدل لایهای باس CAN طبق استاندارد پیادهسازی [۹] — [۱۰]                        |
| ١٠  | شكل ٢-٢: تشخيص وضعيت سيگنال منتقل شده از روى اختلاف ولتاژ CAN_L و CAN_H [١٣]          |
| ۱۱  | شكل ٣-٢: قاب داده باس CAN 1.0 [٧]                                                     |
| ۱۳  | شکل ۲–۴: نمونه انجام داوری بین سه گره روی باس CAN [۱٤]                                |
| ۱۴  | شکل ۲-۵: بخشهای زمانی هر بیت در باس CAN [۱۵]                                          |
| ۱۹  | شكل ٢-۶: مقايسه قالب داده CAN استاندارد و CAN FD]                                     |
| ۲۱  | شکل ۲-۷: مقایسه دو پیکربندی زمانی موجود در CAN FD [۲۰]                                |
| ۲۱  | شکل ۲-۸: شکل موج انتقال داده مبتنی بر CAN FD با نرخ ۱۲Mbps [۲۰]                       |
| CAN | شکل ۲-۹: مقایسه عملکرد زمانی باس CAN استاندارد، باس CAN FD با محموله ۸ بایتی و باس FD |
| ۲۲  | با محموله بیش از ۸ بایت [۲۶]                                                          |
| ۲۶  | شکل ۲-۱۰: نمایش مدل لایهای شبکهای مبتنی بر پروتکل CANOpen [۳۲]                        |
| ٣١  | شکل ۳-۱: باس CAN با استفاده از فرستنده-گیرنده [۳ <sup>٤</sup> ]                       |
| ٣١  | شکل ۳–۲: باس CAN بدون استفاده از فرستنده–گیرنده [۳ <sup>۲</sup> ]                     |
| ٣٣  | شکل ۳–۳: برد Arduino Due از نمای بالا [۳٦]                                            |
| ۳۴  | شکل ۳-۴: تصویر برد Ava3S400 و ادوات جانبی آن [۳۸]                                     |
| ۳۴  | شكل ٣-۵: برد شامل فرستنده-گيرنده TJA 1050شكل ٣-۵: برد شامل فرستنده-گيرنده             |
| ۳۵  | شکل ۳-۶: شماتیک تراشه TJA 1050 از نمای بالا [۳۹]                                      |
| ۳۵  | شکل ۳-۷: نمودار بلوکی عملکردی تابع init                                               |
| ۳۵  | شکل ۳-۸: نمودار بلوکی عملکردی تابع WatchFor                                           |
| ۳۵  | شکل ۳-۹: نمودار بلوکی عملکردی تابع read                                               |
| ۳۵  | شکل ۳-۱۰: نمودار بلوکی عملکردی تابع sendFrame                                         |
| ۴۳  | شکل ۱۱-۳: نمودار بلوکی هسته CTU CAN FD [٤٦]                                           |
| ۴۶  | شکل ۳-۱۲: شماتیک ساختار سختافزاری پیکربندی اول                                        |
| ۴۶  | شکل ۳–۱۳: نمودار توالی پیکربندی اول                                                   |
| ۴٧  | شکا ۳-۳ نشمات کی ساختاب ختاافنا می سکیدندی دوه                                        |

| ۴٧ | شکل ۳–۱۵: نمودار توالی پیکربندی دوم                             |
|----|-----------------------------------------------------------------|
|    | شكل ٣-١۶: شماتيك RTL ماژول سطح بالا در FPGA (پيكربندى اول)      |
| ۵۲ | شکل ۳-۱۷: شماتیک RTL ماژول سطح بالا در FPGA (پیکربندی دوم)      |
| ۵۵ | شکل ۴-۱: شبیهسازی باس CAN روی FPGA                              |
| ۵۵ | شکل ۴-۲: مدار آزمون کنترلکنندههای CAN میکروکنترلر               |
| ۵۶ | شکل ۴-۳: نتیجه آزمون باس CAN روی میکروکنترلر                    |
| ΔΥ | شکل ۴-۴: مدار بررسی عملکرد ارتباطهای CAN FD و CAN FD            |
| ۶٠ | شکل ۴-۵: تاخیر باس ارتباطی بر حسب ترافیک شبکه در هر دو پیکربندی |
| ۶۱ | شکل ۴-۶: ارزیابی با نویز محیطی (پیکربندی دوم)                   |

#### صفحه

# فهرست جداول

| ۱۵ | جدول ۲-۱: مقادیر بخشهای هر بیت زمانی [۹ <sup>۰</sup> ]                         |
|----|--------------------------------------------------------------------------------|
| ۱۶ | جدول ۲-۲: مقایسه باسهای سریال رایج و باس CAN [۱۹] [۱۷]                         |
| ۱٧ | جدول ۲–۳: مقایسه اجمالی بین باسهای CAN، CAN و ۲۳]                              |
| 74 | جدول ۲-۴: مقایسه اجمالی باس CAN و ویرایش CAN FD [۹] CAN FD]-[۲۰]-[۲۸]          |
| ۲۷ | جدول ٢-۵: اشيا ارتباطى پروتكل CANOpen [٣٣]                                     |
| ۲۷ | جدول ۲-۶: اجزا یک بسته ارسالی توسط CANOpen روی بستر CAN 1.0 [۳۳]               |
| ۲۸ | جدول ٢-٧: انديس و نوع اشياء موجود در ديكشنرى اشياء [٣٢]                        |
|    | جدول ٣-١: توضيحات پايههاى تراشه TJA 1050 [٣٩]                                  |
| ۵٠ | جدول ۳-۲: مقادیر زمانی محاسبه شده برای ارتباط صحیح دو برد تحت باس CAN و CAN FD |
|    | جدول ۴-۱: میزان استفاده از منابع سختافزاری در پیکربندی اول                     |
| ۵۸ | جدول ۴-۲: میزان استفاده از منابع سختافزاری در پیکربندی دوم                     |
|    | جدول پ-۱: شرح کد پیادهسازی پیکربندی اول در FPGA                                |
| ٧۴ | جدول پ-۲: شرح کد پیادهسازی پیکربندی دوم در FPGA                                |
| ٧۶ | جدول پ-۳: فایل ایجاد محدودیت برای مسیریابی ورودی و خروجیهای FPGA               |
|    | -<br>جدول پ-۴: شرح کد پیادهسازی پیکربندی اول در میکروکنترلر                    |

فصل اول مقدمه

#### مقدمه

### ١-١- تعريف مساله

بیشک یکی از مهمترین کارکردهای هر روزه ی مهندسی، ارتباطات بین اجزاء مختلف است. درحالی که امروزه کامپیوترها فعالیتهای بیشتر و بیشتری را به عهده می گیرند، اهمیت تبادل داده در حال افزایش میباشد. تبادل داده بین کاربران (چه عوامل انسانی و چه عوامل غیر انسانی) اجازه بازیابی یا ضبط داده، تکثیر و نسخهبرداری داده و البته اجرای عملیاتها به شکل غیر متمرکز را میدهد [۱]. در راستای به کارگیری همین مزایا، واسطهای ارتباطی مختلفی نظیر UART ، I<sup>2</sup>C ، SPI و سیاده سازی و استاندارد شده البته هرکدام ویژگیهای منحصر به فرد خود و مزایا و معایبی دارند که آنها را مناسب کاربردهایی خاص ساخته است.

باس 'CAN' که نخستین بار در سال ۱۹۸۶ توسط شرکت آلمانی بوش' در کنگره ی جامعه مهندسان خودرویی ارائه شد [۲]، تاکنون توجهات زیادی را به خود جلب نموده است. با وجود اینکه این باس نخستین بار به منظور استفاده در صنایع خودرویی معرفی شد [۲]، ویژگیهای منحصر به فرد این باس، آن را برای کاربردهای زیادی در صنایع مختلف به خصوص صنایع هوا و فضا مناسب کرده است [۳]. میزان کاربرد و اهمیت این باس در طول سال به قدری افزایش یافت که جزئیات پیادهسازی و ارزیابی این باس، در طول سالهای 1000 ۲۰۱۵ تا 1000 میلادی در قالب ۶ استاندارد سازمان بین المللی ارائه گردید

<sup>&</sup>lt;sup>1</sup> Controlled Area Network

<sup>&</sup>lt;sup>2</sup> Robert Bosch GmbH

<sup>&</sup>lt;sup>3</sup> Society of Automotive Engineers (SAE) congress

[۴]. در پی افزایش کاربردهای باس CAN، نسخههای دیگری از این باس ارائه شدند که در این میان میان میان میتوان به CAN FD اشاره نمود [۲].

باس CAN FD نخستین بار در سال ۲۰۱۲ عرضه شد و هدف اصلی معرفی این ویرایش خاص از باس ،رد (۱۰]. باس ،دم ،پشتیبانی از نرخهای انتقال بالا همزمان با افزایش اطمینانپذیری این باس بود (۱۰]. باس CAN FD با قیمتی مشابه به CAN استاندارد، سرعتی چند برابر آن را ارائه میکند (۱۱]. در راه طراحی CAN FD تلاش بر این بود که لایه فیزیکی CAN حفظ شده و تنها لایههای بالاتر تغییر کنند، بنابراین CAN FD را میتوان یک پروتکل برای لایه فیزیکی CAN استاندارد نیز دانست.

با وجود تمام خواص ارزشمند باس CAN و همچنین نسخه بهبود یافته آن یعنی CAN FD، این باس تنها ارتباط در لایههای پایین تر را فراهم می کند و روشی برای ارتباط در لایههای بالاتر و به ویژه لایه کاربرد<sup>۲</sup> فراهم نمی کند [7]. بنابراین برای استفاده موثر از این باس در کاربردهایی با مقیاس بالا، نیاز به پروتکلهایی می باشد که ویژگیهای لایه کاربرد را فراهم کنند. یکی از این پروتکلها، پروتکل پروتکل CANOpen می باشد که امروزه به طور گسترده در صنایع اتوماسیون مورد استفاده قرار می گیرد. این پروتکل قابلیتهای نظیر تقطیع بسته، همگامسازی شبکه و مدیریت گرهها را فراهم می آورد [8].

هدف این پروژه، پیادهسازی یک ارتباط از طریق CAN بین یک میکروکنترلر و یک FPGA و همچنین پیادهسازی باس CAN FD به صورت حلقه بازگشتی درون FPGA میباشد. همانطور که پیشتر اشاره شد، باس CAN FD استاندارد دارای سه لایه شی، انتقال و فیزیکی میباشد و CAN FD با استفاده از لایه فیزیکی باس CAN به پیادهسازی دو لایه بالاتر میپردازند. این لایه فیزیکی از طریق یک جفت سیم

\_

<sup>&</sup>lt;sup>1</sup> Flexible Date rate CAN

<sup>&</sup>lt;sup>2</sup> Application layer

<sup>&</sup>lt;sup>3</sup> Loopback

درهم تنیده (رابط باس CAN) و دستگاههای فرستنده-گیرنده انجام می شود. در نهایت نیز ارتباط بین اجزاء از طریق پروژه، مطابق شکل ۱-۱ اجزاء از طریق پروژه، مطابق شکل ۱-۱ می باشد.



شکل ۱-۱: نمودار بلوکی اجزاء پروژه.

## ۱-۲- ضرورت و اهداف پروژه

همانطور که ذکر شد، باس CAN FD تاریخچه کوتاهتری از CAN استاندارد دارد و به طبع در تحقیقات و صنایع مختلف، توجه کمتری به آن شده است. با توجه به اینکه CAN FD به صورت بالقوه می تواند با قیمتی یکسان با CAN استاندارد، کارایی بالاتری ارائه دهد [٦] و عملا بدون ایجاد هزینه اضافی جایگزین باس CAN FD شود، وجود یک روش ساختارمند برای کار با CAN FD بسیار ارزشمند خواهد بود.

خروجی نهایی این پروژه، میتواند به صورت یک کتابخانه نرمافزاری (برای میکرکنترلر) و یک IP-Core خروجی نهایی این پروژه، میتواند به صورت یک کتابخانه نرمافزاری (برای FPGA) درآید که هر کدام از این موارد به خودی خود میتوانند استفاده از FPGA را در

-

<sup>&</sup>lt;sup>1</sup> Transceiver

آینده تسهیل نمایند. این فرایند می تواند به رشد استفاده از CAN FD در صنایع مختلف و در نتیجه بهبود کیفیت ارتباطات سریال و در نتیجه افزایش کارایی ادوات مختلف، کمک بسزایی نماید.

### ۱-۳- ساختار گزارش

در فصل ابتدایی این گزارش، مقدمهای اجمالی بر روی طرح انجام گرفته، اهداف دنبال شده و ضرورت اجرای این طرح ارائه شد. در فصل دوم، به طور تفضیلی به ویژگیهای باس CAN، کاربردهای آن و مقایسه آن با سایر باسهای مطرح در سیستمهای نفهته پرداخته شده است. همچنین به طور دقیق تر تفاوتهای برخی نسخههای دیگر باس CAN و به ویژه CAN FD با باس CAN بررسی شده است و در پایان نیز پروتکلهای لایه بالاتر به خصوص CANOpen مورد بررسی قرار گرفته است. در فصل سوم، پیادهسازی انجام شده در میکروکنترلر و FPGA بیان شده است. این موضوع شامل بررسی قطعات و کتابخانههای نرمافزاری مورد استفاده و همچنین ساختار سختافزاری و ساختار نرمافزاری پیادهسازی شده میشود. در فصل چهارم، پیادهسازی انجام شده مورد ارزیابی قرار گرفته است و عملکرد طرح بررسی شده است. فصل پایانی نیز به بیان نتایج و پیشنهادات حاصل از انجام این طرح پرداخته است.

فصل دوم باس CAN

# باس CAN

باس سریال CAN نخستین بار در سال ۱۹۸۶ توسط شرکت بوش به صورت یک سیستم همه پخشی  $^{1}$ ، با قابلیت پشتیانی از چندین راهبر  $^{7}$  و به صورت آسنکرون  $^{7}$  توسعه پیدا کرد. هدف اولیه این باس که بعدها در قالب استاندارد ISO 11898 قرار گرفت، جایگزینی این باس در صنایع خودروسازی به دلیل مشکلات پیچیدگی و سیم کشی باسهای دو-سیمه موجود بود  $[^{9}]$ . در ادامه، این باس محبوبیت زیادی در بین واحدهای کنترل، حسگرها، سیستمهای ضد لرزش و سایر واحدهای کنترل الکتریکی  $^{7}$  پیدا کرد  $[^{1}]$ . حداکثر نرخ ارسال این باس برابر Mbps میباشد که مقاومت آن در برابر اختلالات الکتریکی و قابلیت شناسایی و تصحیح خطاها به صورت خودکار، این باس را مناسب برای کاربردهای ذکر شده نموده است. طبق استاندارد ISO 11898 مشخصات این باس در دو بخش  $^{8}$  و دو ویرایش یک و دو منتشر شده است  $^{9}$ . به طور کلی، می توان مزایای کلیدی باس CAN را در چند مورد اساسی خلاصه نمود:

- سادگی و پیادهسازی ارزان قیمت
  - متمرکز<sup>۵</sup> بودن
  - اطمینانپذیری بالا
  - کارایی مناسب [۷]

علل وجود هر یک از این مزیتها در ادامه مشخص خواهد شد.

با وجود اینکه این باس نخستین بار به منظور استفاده در صنایع خودرویی معرفی شد [۲]، ویژگیهای منحصر به فرد این باس، آن را برای کاربردهای زیادی در صنایع مختلف به خصوص صنایع اتوماسیون هوا و فضا مناسب کرده است [۲]، [۳] و [۲۱]. پس از توسعه ویرایش اولیه این باس برای خودروهای

٧

<sup>&</sup>lt;sup>1</sup> Broadcast

<sup>&</sup>lt;sup>2</sup> Master

<sup>&</sup>lt;sup>3</sup> Asynchronous

<sup>&</sup>lt;sup>4</sup> Electronic Control Unit (ECU)

<sup>&</sup>lt;sup>5</sup> Centralized

دارای سرنشین، از این باس به عنوان پروتکل ارتباطی برای کاربردهایی نظیر سیستمهای کنترل آسانسور، مدیریت ماشین آلات نساجی و همچنین دستگاههای تولید اشعه X-Ray مورد استفاده قرار گرفت [۲].

# ۱-۲- ویژگیهای فنی

معماری یک باس CAN از سه لایه تشکیل میشود که عبارتند از:

- لايه شي ' CAN
- لايه انتقال ۲ CAN
- لایه فیزیکی CAN

در بین این موارد، مجموعه دو لایه شی و انتقال، معادل لایه لینک داده در مدل مرجع ISO/OSI هستند. لایه شی مسئول انتخاب پیام، انتخاب زمان ارسال آن و در نهایت ارتباط با لایههای بالاتر است. لایه انتقال نیز مسئوال اجرای پروتکل انتقال است که شامل موارد نظیر داوری، تشخیص خطا و کنترل قالبهای ارسالی میشود. لایه فیزیکی نیز نمایانگر بستر حقیقی انتقال بیتهای داده است [۱۰]. شکل ۲-۱، ساختار معماری این باس را بهتر نمایان میکنند.

1

<sup>&</sup>lt;sup>1</sup> Object Layer

<sup>&</sup>lt;sup>2</sup> Transfer layer



شکل ۲-۱: مدل لایهای باس CAN طبق استاندارد پیادهسازی [9] - [10]

### ۱-۱-۲ لايه فيزيكي

V این فیزیکی باس، رابط انتقال به صورت یک جفت سیم درهم تنیده میباشد. سیمهای موجود در این جفت که CANH و CANL نامیده میشوند، مسئول انتقال داده باس CAN هستند. سیگنالها به صورت تفاضلی و متعادل وی این سیمها جابجا میشوند، که این موضوع عامل اصلی خنثی سازی اثر نویزهای محیطی میباشد V و مورد استفاده قرار گرفته است V استفاده قرار گرفته استفاده قرار گرفته استفاد و سند و س

طبق استاندارد، در لایه فیزیکی باس CAN، دو نوع وضعیت سیگنال متفاوت تعریف شده است: وضعیت غالب  $^{\dagger}$  (سیگنال صفر منطقی) و وضعیت مغلوب  $^{6}$  (سیگنال یک منطقی). همانطور که ذکر شد، این سیگنالها توسط دو رشته سیم در هم تنیده ارسال می شوند و تفاوت ولتاژ این دو سیم  $(V_{DIFF})$ ، وضعیت سیگنال انتقالی را مشخص می نماید. برابری ولتاژ (DIFC) به معنی وضعیت مغلوب و اختلافی بیش از مقدار از پیش تعیین شده (عموما برابر (DIFC)) نشان دهنده وضعیت غالب می می باشد (DIFC)

<sup>&</sup>lt;sup>1</sup> twisted-pair wires

<sup>&</sup>lt;sup>2</sup> Differential

<sup>&</sup>lt;sup>3</sup> Balanced

<sup>&</sup>lt;sup>4</sup> Dominant

<sup>&</sup>lt;sup>5</sup> Recessive

استاندارد ISO-11898، حداکثر طول کابل مناسب باس CAN برای ارسال با نرخ بیتی ISO-11898 را برابر ۴۰ متر اعلام کرده است [٤]. البته که استفاده از کابلهای طولانی تر نیز برای این باس امکان پذیر است، ولی در صورت استفاده از کابلهای طولانی تر، نرخ بیتی به شکل قابل ملاحظهای کاهش می یابد. به عنوان یک مثال، یک باس CAN با طول کابل برابر ۵۰۰ متر، حداکثر نرخ بیتی ۱۲۵Kbps را خواهد داشت [۱۳].



شكل ٢-٢: تشخيص وضعيت سيكنال منتقل شده از روى اختلاف ولتارٌ CAN\_H و CAN\_H [18] [18]

### ۲-۱-۲ لایه لینک داده

لایه لینک داده در باس CAN، وظایفی نظیر قالببندی دادهها، داوری<sup>۱</sup>، تشخیص خطا وکنترل دسترسی به باس را بر عهده دارد [۱۰]. همانطور که در شکل 1-1 نمایش داده شد، لایه لینک داده از دو زیرلایه به نامها کنترل لینک منطقی (LLC) و کنترل دسترسی به واسط (MAC) تشکیل شده است. زیر لایه LLC مسئول ارائه خدمات تصدیق داده، ایجاد اطلاعیهها و مدیریت بازیابی میباشد. زیر لایه MAC نیز وظیفه کپسولهسازی دادهها، کدگذاری قابها، مدیریت دسترسی به واسط، تشخیص و اطلاع خطا و همچنین مدیریت  $1^{12}$  همیباشد  $1^{12}$  قابل اطلاع خطا و همچنین مدیریت مربوط به هر یک از بخشهای این قاب در ادامه بیان شده است.

| S<br>O<br>F | 11-Bit Identifier |  | - D E | r0 | DLC | 08 Bytes Data | CRC | ACK | EOF | FS |  |
|-------------|-------------------|--|-------|----|-----|---------------|-----|-----|-----|----|--|
|-------------|-------------------|--|-------|----|-----|---------------|-----|-----|-----|----|--|

شكل ٢-٣: قاب داده باس CAN 1.0 [<sup>٧</sup>]

SOF: بخشی یک بیتی است که شروع انتقال بسته را مشخص میکند و عموما به صورت بیت صفر غالب است.

Identifier: یک شناساگر منحصر به فرد پیام است که علاوه بر مشخص کردن نوع پیام، وظیفه اصلی آن مشخص کردن اولویت بالاتر پیام است. کمتر بودن مقدار این بخش به معنای اولویت بالاتر پیام است و در مرحله داوری، پیامهایی که اولویت بالاتری دارند پیش از سایر پیامها ارسال میشوند. تفاوت اصلی استاندارد CAN 1.0 برابر ۱۹ بیت و برای در طول همین بخش است که برای CAN 1.0 برابر ۲۹ بیت میباشد.

<sup>&</sup>lt;sup>1</sup> Arbitration

<sup>&</sup>lt;sup>2</sup> Logical Link Control

<sup>&</sup>lt;sup>3</sup> Medium Access Control

<sup>&</sup>lt;sup>4</sup> Data Frame

(RTR (Remote Transmission Request: بخشی یک بیتی است که نشانگر این است که پیام ارسالی درخواست ارسال داده است (بیت یک منطقی) و یا خود داده می باشد (بیت صفر منطقی).

(Identifier extension bit) نقداری یک بیتی که مشخص میکند شناساگر ۱۱ بیتی است (صفر منطقی) و یا ۲۹ بیتی (یک منطقی).

r0: مقدار یک بیتی رزرو شده است که میتواند هر مقداری بپذیرد، ولی به صورت متداول برابر صفر منطقی قرار میگیرد.

(Data length code) مقداری چهار بیتی که تعداد بایتهای داده را نشان میدهد.

Data: محموله داده اصلی هر بسته که حداکثر برابر هشت بایت می باشد.

CRC: کد افزونگی چرخشی داده ارسالی که طول آن ۱۵ بیت میباشد (به همراه یک بیت اضافه برای مشخص شدن یایان CRC).

ACK: مقداری ۱ بیتی برای ارسال و دریافت ACK میباشد. فرستنده پیام مقدار یک مغلوب را درون این بخش قرار می دهد. این بخش مینویسد و گیرنده نیز پس از دریافت پیام، مقدار صفر غالب را درون این بخش قرار می دهد.

EOF: نشانگر پایان یک بسته میباشد و همواره مقداری یک بیتی برابر یک منطقی میباشد.

(Inter Frame Spacing: بخشی سه بیتی است که به منظور ایجاد فاصله بین پیامهای متوالی IFS (Inter Frame Spacing) قرار داده می شود و تمامی بیتهای آن برابر یک منطقی می باشند [۱۰].

البته که در یک ارتباط CAN لزوما تمامی بخشهای ذکر شده مورد استفاده قرار نمی گیرند، بلکه بسته به کاربری بسته، ممکن است هر یک از بخشها به صورت انتخابی استفاده شوند. بستههای CAN به طور کلی می توانند چهار کاربرد متفاوت داشته باشند:

۱. بسته داده: این نوع بسته به منظور ارسال یک محموله از داده مورد استفاده قرار می گیرد.

- ۲. بسته راه دور ۱: هدف از ارسال این نوع بستهها، درخواست دادهای خاص میباشد.
- ۳. بسته خطا: در صورتی که خطایی در ارسال و یا دریافت داده ایجاد شود، گره مربوطه این نوع ییام را روی باس مخابره می کند.
- ۴. بسته اضافه بار  $^{7}$ : هر گره می تواند با ارسال این نوع بسته روی باس، از گرههای دیگر تقاضا کند  $^{8}$ . که برای ارسال بستههای بعدی مدتی صبر کنند  $^{8}$ .



شکل ۴-۴: نمونه انجام داوری بین سه گره روی باس CAN. در اینجا سه گره به طور همزمان شروع به ارسال بسته میکنند، ولی از آنجایی که مقدار شناساگر گره سوم کمتر میباشد، مقدار غالب باس شده و برندهی این داوری میباشد [<sup>۱۴</sup>].

علاوه بر ویژگیهای ذکر شده برای قاب داده، عملیات پر کردن (لاگذاری) بیتی تنیز در هنگام ارسال قاب داده انجام می شود. این عملیات از طریق قراردادن (لاگذاری) یک بیت مخالف بعد از هر پنج بیت یکسان انجام می شود (بجز بخشهای CRC و ACK) و هدف اصلی آن، کاهش خطاهای باس می باشد [۷].

<sup>2</sup> Overload

<sup>&</sup>lt;sup>1</sup> Remote

<sup>&</sup>lt;sup>3</sup> Bit Stuffing

ویژگی مهم دیگری که به هنگام بررسی باس CAN باید مد نظر قرار داده شود، مفهوم زمان بیتی است. از آنجایی که باس CAN یک باس آسنکرون میباشد، باید ساز و کاری وجود داشته باشد که باعث اطمینان از صحت همگامی ارتباط شود. به همین منظور، زمان ارسال هر بیت در باس CAN به چهار قسمت تقسیم میشود. نام این قسمتها عبارت است از: PROP\_SEG ،SYNC\_SEG، این زمانها PHASE\_SEG 2 و PHASE\_SEG 1 مقدار زمان بیتی اسمی (TNBT)، برابر مجموع این زمانها میباشد [۱۰].



شکل ۲-۵: بخشهای زمانی هر بیت در باس CAN [۱۵]

کوچکترین قطعه زمان در دامنه مفاهیم باس CAN، با نام کوانتوم زمان  $^{7}$  یا  $^{7}$  شناخته می شود. این مقدار را می توان برابر زمان هر کلاک CAN در نظر گرفت. کلاک اکلی CAN نیز از تقسیم کلاک اصلی سیستم بر مقداری که با نام Prescaler شناخته می شود محاسبه می گردد. با توجه به مقدار  $^{7}$  و البته نیازمندی های نرخ داده هر کاربرد، می تواند مقادیر متغیرهای زمانی را محاسبه نمود  $^{7}$ . جدول  $^{7}$  توضیحات محاسبه هر یک از این بخش ها را ارائه می دهد.

\_

<sup>&</sup>lt;sup>1</sup> Bit Time

<sup>&</sup>lt;sup>2</sup> Time Quantum

جدول ۲-۱: مقادیر بخشهای هر بیت زمانی [۵].

| توضيحات                                                        | مقدار زمانی                           | نام بخش     |
|----------------------------------------------------------------|---------------------------------------|-------------|
| همواره مقداری ثابت دارد.                                       | یک کوانتوم زمانی                      | SYNC_SEG    |
| مقدار آن وابسته به طول باس و جنس<br>کابلها و اتصالات میباشد.   | بین یک تا هشت کوانتوم زمانی           | PROP_SEG    |
| هدف اصلی آن، ایجاد تحمل کافی برای<br>خطاها و ایجاد همگامی است. | بین یک تا هشت کوانتوم زمانی           | PHASE_SEG 1 |
| هدفی مشابه PHASE_SEG 1 دارد.                                   | مقدار بزرگتر بین دو مقدار PHASE_SEG 1 | PHASE_SEG 2 |

## ۲-۲- مقایسه باس CAN با باسهای دیگر

در مقابل باس CAN، باسهای سریال زیادی وجود دارند که به صورت گسترده در صنایع مختلف مورد استفاده قرار می گیرند. در این میان می توان به باسهای I2C ،SPI و USART اشاره نمود. جدول ۲-۲ مقایسهای اجمالی بین این باسها را به نمایش می کشد. معماری Multi-Master، مختص به پروتکلهای ارتباطی می باشد که هر یک از گرههای متصل به شبکه می توانند اقدام به شروع مخابره کنند، در مقابل این موضوع معماری Single-Master قرار دارد که بدان معنی است که تنها یک گره می تواند اقدام به شروع مخابره نماید [۱۹]. انتقال سنکرون نیز به معنی وجود سیگنال کلاک مشترک بین گرههای متصل به باس بوده و انتقال آسنکرون نیز عدم وجود چنین سیگنالی را نشان می دهد [۱۹].

<sup>ٔ</sup> Information Proccessing Time: زمان پردازش اطلاعات که عموما برابر دو کوانتوم زمانی است.

جدول ٢-١: مقايسه باسهاي سريال رايج و باس CAN [١٩]-[١٧]. [١٠].

| USART                  | SPI               | I2C              | USART                     | CAN              |                         |
|------------------------|-------------------|------------------|---------------------------|------------------|-------------------------|
| وابسته به طرفین ارتباط | 60 Mbps           | 3.4 Mbps         | وابسته به<br>طرفین ارتباط | 1 Mbps           | حداکثر نرخ<br>داده      |
| نقطه به نقطه           | نقطه به نقطه      | باس خطی          | نقطه به نقطه              | باس خطی          | توپولوژی                |
| Multi-<br>Master       | Single-<br>Master | Multi-<br>Master | Multi-<br>Master          | Multi-<br>master | معماری                  |
| آسنكرون                | آسنكرون           | سنكرون           | آسنكرون                   | آسنكرون          | نوع انتقال<br>پیام      |
| -                      | -                 | بله              | -                         | بله              | دارای<br>پروتکل<br>مشخص |
| -                      | -                 | -                | -                         | CRC              | تشخيص خطا               |
| -                      | -                 | -                | -                         | بله              | مقاومت در<br>برابر نویز |

علاوه بر باسهای سریال، باسهای دیگری نیز وجود دارند که با اهدافی مشابه CAN و عموما به هدف استفاده در صنایع خودروسازی توسعه یافتهاند. از جمله این باسها میتوان به MOST ،LIN و FlexRay اشاره نمود [۲۰]-[۲۰]. در جدول ۲-۳، مقایسهای اجمالی بین این باسها انجا شده است. عملکرد پروتکل دسترسی CSMA به این صورت میباشد که که هر گره، پیش از ارسال هر پیام وضعیت باس را بررسی کرده و از عدم وجود ترافیک روی باس اطمینان مییابد [۲۰]. پروتکل TDMA نیز زمان را به بخشهای مساوی تقسیم کرده و هر گره مجاز است در بخشهای زمانی مشخصی اقدام به ارسال و یا دریافت نماید. کاربرد بلادرنگ سخت، به این معناست که عدم توانایی سیستم در انجام حتی یک عملکرد پیش از ضربالعجل مشخص، به معنای خرابی کل سیستم است، در حالی که در کاربردهای بلادرنگ نرم، تعداد کمی از دیرکردها قابل پذیرش هستند [۲۲].

جدول ۲-۲: مقايسه اجمالي بين باسهاي CAN، CAN و MOST [۲۳].

| MOST                         | FlexRay               | LIN           | CAN                            |                          |
|------------------------------|-----------------------|---------------|--------------------------------|--------------------------|
| 24 Mbps                      | Mbps 10 Mbps 20 Kbps  |               | 1 Mbps                         | حداکثر نرخ داده          |
| TDM<br>CSMA/CA               | TDMA                  | Polling       | CSMA/CA                        | پروتکل<br>دسترس <i>ی</i> |
| دو سیم مبتنی بر<br>فیبر نوری | دو سیم و فیبر<br>نوری | یک سیم        | دو سیم                         | لایه فیزیکی              |
| Multi-master                 | Multi-master          | Single master | Multi-master                   | معماري                   |
| آسنکرون و<br>سنکرون          |                       |               | آسنكرون                        | نوع انتقال پیام          |
| بلادرنگ سخت چندرسانهای       |                       | زير شبكهها    | بلادرنگ نرم                    | کاربرد                   |
| وابسته به جریان<br>داده      | ثابت                  | ثابت          | وابسته به میزان<br>ترافیک شبکه | تاخير                    |

# ۲-۳- ویرایشهای باس CAN

به منظور رفع برخی مشکلات باس CAN و یا افزودن برخی قابلیتهای خاص، به طور مثال افزایش نرخ انتقال داده و یا افزایش اطمینانپذیری، ویرایشهای مختلفی از این باس ارائه شده است. از میان این ویرایشهای متفاوت این باس، میتوان به Time Triggered CAN) TTCAN ویرایشهای متفاوت این باس، میتوان به Flexible Data-Rate) اشاره نمود.

#### TTCAN - 1 - 4 - 4

TTCAN ویرایشی از باس CAN میباشد که برای کاربردهایی با درجه بلادرنگ بودن بالا توسعه یافته است و در استاندارد ISO-11898 نیز شرح داده شدهاست. یکی از مشکلاتی که امکان وجود آن در باس

CAN استاندارد وجود دارد، استفاده بیرویه یکی از گرهها از باس مشترک است. بدین صورت که یک گره با ارسال پیامهای متوالی با مقدار شناساگر کم (اولویت بالا) باس را در اختیار گرفته و سایر گرهها توان استفاده درست از باس را نخواهند داشت. و این موضوع میتواند برای کاربردهای بلادرنگ مشکل ساز باشد [۲۶].

به منظور رفع مشکل ذکر شده، TTCAN رویکردی جدید برای استفاده از باس مشترک در نظر می گیرد. در این رویکرد، یکی از گرههای شبکه نقش راهبر شبکه را در اختیار گرفته و دو وظیفه اساسی را بر عهده دارد: ۱. همگامسازی زمانی گرهها از طریق مخابره همگانی یک شکاف زمانی. ۲. برنامه ریزی زمانی ارسال پیام از طریق یک ماتریس زمان بندی شده یک سیکل زمانی است و سه نوع سیکل زمانی مختلف وجود دارد: ۱. سیکلهای زمانی که مخصوص ارسال پیامی خاص می باشد. ۲. سیکلهای زمانی که مشابه CAN استاندارد، داوری بر اساس اولویت شناساگر انجام می شود. ۳. سیکلهای زمانی که هیچ گرهای در آن نمی تواند به مخابره پیام بپردازد و برای استفادههای دیگر رز رو شده است [ 27 ].

#### CAN FD - 7 - 7 - 7

مهندسان شرکت بوش در سال ۲۰۱۲ باس CAN FD را معرفی کردند. هدف اصلی معرفی این ویرایش خاص از باعث CAN، پشتیبانی از نرخهای انتقال بالاتر از Mbps در کنار افزایش اندازه محموله هر خاص از باعث CAN، پشتیبانی از نرخهای انتقال بالاتر از CAN FD در کنار افزایش اندازه محموله قاب به مقادیر بیشتر از هشت بایت بود [۹]. باس CAN FD با قیمتی مشابه به CAN FD استاندارد، سرعتی چند برابر آن را ارائه می کند، البته موضوع به همینجا ختم نمی شود و CAN FD ساز و کار پیشرفته تری برای تشخیص خطا نیز دارد [۱]. در راه طراحی CAN FD، تلاش بر این بود که لایه فیزیکی CAN FD حفظ شده و تنها لایههای بالاتر تغییر کنند، بنابراین CAN FD را می توان یک پروتکل برای لایه فیزیکی CAN FD استاندارد نیز دانست. به طور کلی افزایش نرخ داده ذکر شده در CAN FD از

<sup>&</sup>lt;sup>1</sup> Master

<sup>&</sup>lt;sup>2</sup> Schedule matrix

<sup>3</sup> Payload

دو طریق تغییر صورت گرفته است: ۱. افزایش نسبت محموله به سرآیند در هر قاب داده، ۲. کوتاه کردن زمان بیتی <sup>۱</sup> [۵]. شکل ۲-۶، مقایسهای بین یک قاب CAN FD استاندارد و قاب CAN FD را نشان میدهد.



شكل ٢-۶: مقايسه قالب داده CAN استاندارد و CAN FD [٥]

همانطور که از شکل ۲-۶ بر می آید، تفاوت عمده قاب داده CAN و CAN FD در دو بخش می ایت CRC دو باس خلاصه می شود. محموله داده یک پیام CAN استاندارد می تواند حداکثر هشت بایت باشد، در حالی که محموله داده پیام CAN FD می تواند طولی برابر ۶۴ بایت داشته باشد. همچنین طول CAN در CAN FD می تواند ۱۲ بایت باشد (در مقابل ۱۵ بایت در CAN FD استاندارد) در [۹]-[۹].

البته که افزایش نرخ داده CAN FD تنها توسط افزایش طول محموله داده هر پیام محقق نمی شود، بلکه ساز و کاری برای کاهش زمان بیتی نیز به کار گرفته شده است. ایده اصلی استفاده از این ساز و کار این است که هنگامی که عملیات داوری انجام شده و یک پیام برنده داوری شد، پیام مورد نظر می تواند بدون توجه به محدودیتهای زمانی و بدون همگامسازی با همه گرههای شبکه، به ارسال بخش محموله پیام بپردازد [ $^{\circ}$  ]. وجود این ساز و کار در کنار افزایش طول محموله هر پیام، می تواند نرخ ارسال داده را تا مقادیری بیش از Mbps افزایش داده که مقادیری تا حدود CAN FD متداول است، هرچند که مقادیر بزرگ تر از این مقدار نیز بسته به شرایط ممکن است [ $^{\circ}$ ].

<sup>&</sup>lt;sup>1</sup> Bit Time

در واقع کنترلکننده باس CAN FD دارای دو پیکربندی زمانی است. پیکربندی زمانی اول، مشابه جدول ۲-۱ بوده و در مرحله داوری یک انتقال مورد استفاده قرار می گیرد. بنابراین در این مرحله، نرخ ارسال داده همچنان حداکثر برابر ۱Mbps میباشد. پیکربندی زمانی دوم (زمان بیتی کوتاه) نیز مختص زمان ارسال محموله است. این پیکربندی زمانی، دارای کوانتومهای زمانی با طول کوتاهتر بوده که باعث ارسال هر بیت با سرعتی بیشتر میشود. البته که ممکن است دو پیکربندی زمانی ذکر شده کاملا یکسان باشند و این موضوع وابسته به نیازمندیهای موجود در هر پیادهسازی میباشد. علاوه بر مرحله داوری، در مرحله ارسال داده CRC نیز از پیکربندی زمانی اول استفاده میشود تا اطمینانپذیری انتقال بیشتر شود [۲۰]. شکل ۲-۷ مقایسهای بین زمان بیتی کوتاه و معمولی را نشان میدهد. شکل ۲-۷ نیز یک شکل موج از ارسال داده مبتنی بر باس CAN FD را به نمایش میگذارد که در این ارتباط، پیکربندی زمانی دوم دارای کوانتومهای زمانی به مراتب کوتاهتر از پیکربندی اول است. بنابراین به وضوح بیتهای محموله با نرخ بسیار بالاتری روی خطوط باس منتقل شده و نرخ ارسال کلی افزایش چشم گیری خواهد محموله با نرخ بسیار بالاتری روی خطوط باس منتقل شده و نرخ ارسال کلی افزایش چشم گیری خواهد



شکل ۲-۷: مقایسه دو پیکربندی زمانی موجود در CAN FD [۲۵]



شكل ٢-٨: شكل موج انتقال داده مبتنى بر CAN FD با نرخ ١٢Mbps [٢٥].

شکل 7-9، مقایسهای زمانی بین CAN FD و CAN FD را به نمایش می کشد. در این مطالعه، در نظر گرفته شده است که هشت سطح اولویت متفاوت در یک سیستم وجود دارد و به طور تقریبا همزمان، درخواستی برای دادههای با اولویتهای متفاوت ایجاد می شود. در پایان، بیشترین زمان پاسخگویی گرهها برای پیامهای با اولویتهای مختلف اندازه گیری و مقایسه شده است [77]. نتایج بدست آمده، حاکی از برتری چند برابری زمان پاسخگویی در CAN FD نسبت به CAN استاندارد می باشد.



شکل ۲-۹: مقایسه عملکرد زمانی باس CAN استاندارد، باس CAN FD با محموله ۸ بایتی و باس CAN FD با محموله بیش از ۸ بایت [۲۹].

تغییری دیگری که برای بکارگیری CAN FD نیاز است، وجود بخشهایی برای تمیز پیام CAN FD از پیام CAN FD استاندارد و همچنین نوع ارسال پیام میباشد. به همین منظور، دو بخشی که در ادامه معرفی میشوند، در قاب CAN FD گنجانده شدهاند:

(FDF (FD frame: این بخش یک بیتی جایگزین بخش رزرو CAN در CAN استاندارد شده است و اگر مقدار آن برابر یک مغلوب باشد، نشان دهنده ی این است که پیام ارسالی از نوع CAN FD است.

res: این بخش یکی بیتی به قاب CAN FD به عنوان بیت رزرو افزوده شده است و مقدار آن باید برابر یک مغلوب باشد. (BRS (Bit Rate Switch) این بخش یک بیتی، برای فعال یا غیرفعالسازی استفاده از ساز و کار BRS (الله Rate Switch) کاهش زمانبیتی است. در صورتی که مقدار صفر غالب را پذیرفته باشد، بسته CAN FD با نرخ حداکثر ۱Mbps ارسال شده و در غیر این صورت، با کاهش زمانبیتی، دستیابی به نرخهای ارسال بالاتر نیز ممکن میشود.

(Error Status Indicator: در صورت که مقدار یک غالب داشته باشد، ارتباط موجود نسبت به وجود خطاها حساس است و در غیر این صورت، ارتباط از خطاها صرف نظر می کند.

(SBC (Stuff Bit Count): بخشی چهار بیتی است که شامل بیتهای parity بوده و برای افزایش اطمینان پذیری به قاب CAN FD افزوده شده است [۲۷].

CAN FD چهار ساز و کار مختلف به منظور تشخیص و اصلاح خطا ارائه می دهد که دو مورد از آنها در لایه فیزیکی صورت گرفته و دو مورد باقی مانده در لایه لینک داده اعمال می شوند. این ساز و کارها عبار تند از:

نظارت بر بیت<sup>۱</sup>: کنترلکننده باس، مقداری که قصد ارسال آن را داشته با مقداری که روی باس قرار گرفته است مقایسه کرده از این طریق صحت ارسال را بررسی میکند.

پر کردن بیتی: استفاده از یک بیت با قطبیت مخالف پس از پنج بیت با قطبیت یکسان که به منظور تشخیص دقیق تر بیت ارسالی می باشد.

CRC: استفاده از کد افزونگی چرخشی داده ارسالی که طول آن ۱۷ بیت (برای محمولههایی با اندازه کمتر از ۱۷ بایت) و یا ۲۱ بیت می باشد.

بررسی قاب پیام: در سطح پیامهای دریافتی، تطابق قاب دریافتی با استاندارد پروتکل CAN FD بررسی میشود.

\_

<sup>&</sup>lt;sup>1</sup> Bit Monitoring

علاوه بر ساز و کارهای فوق به منظور تشخیص خطا، امکان استفاده از پیامهای ACK نیز وجود دارد [۲۸].

جدول ۲-۳: مقايسه اجمالي باس CAN و ويرايش CAN FD [٩] -[٩] -[٩] -[٢٨]

| CAN FD                       | CAN                          | مشخصه                 |
|------------------------------|------------------------------|-----------------------|
| سیگنال تفاضلی روی جفت سیم    | سیگنال تفاضلی روی جفت سیم    | لايه فيزيكى           |
| در هم تنیده                  | در هم تنیده                  |                       |
| ۴۰ متر (طبق استاندارد)       | ۴۰ متر (طبق استاندارد)       | حداكثر طول باس        |
| حداكثر ۵Mbps (طبق            | حداكثر ۱Mbps                 | نرخ انتقال داده       |
| استاندارد)                   |                              |                       |
| حداکثر ۶۴ بایت               | حداکثر ۸ بایت                | طول محموله هر پيام    |
| ۲۹ بیت (یا ۱۱ بیت)           | ۲۹ بیت (یا ۱۱ بیت)           | طول شناساگر پیام (ID) |
| ۱۷ یا ۲۱ بیت                 | ۱۵ بیت                       | طول کد بررسی CRC      |
| دو پیکربندی متفاوت، یکی از   | یک پیکربندی به کوانتوم زمانی | زمان بیتی             |
| آنها کوتاه است و دیگری مشابه | طولانی                       |                       |
| CAN استاندارد                |                              |                       |
| می تواند طوری پیکربندی شود   | با CAN FD سازگار نمیباشد     | سازگاری               |
| که مشابه CAN عمل کند.        |                              |                       |

### CAN یروتکلهای لایههای بالاتر سازگار با $\xi$ -۲-

همانطور که پیشتر ذکر شد، در استاندارد باس CAN تنها به پیادهسازی لایه فیزیکی و لایه لینک داده پرداخته شده است  $[^{\sharp}]$ . بنابراین به منظور استفاده بهینه از باس CAN در مقیاس بزرگ، نیاز به پروتکلهایی وجود دارد که در لایه کاربرد پیادهسازی شده باشند و سطح تجرید مناسبی برای استفاده کاربران و طراحان سیستم ایجاد کنند. پروتکلهای مختلفی در راستای همین نیاز ارائه شدهاند که در ادامه به اختصار به برخی از آنها پرداخته شده است.

#### ۱-۴-۲ يروتكل OBD2

پروتکل (On Board Diagnostics) به هدف تسهیل عیبیابی خودروها و کامیونهای سبک طراحی شده است. از سال ۱۹۹۶ میلادی به بعد، قانونا باید درون همه خودروهای آمریکای شمالی پیادهسازی شده باشد. وجود این پروتکل به کاربران اجازه میدهد که با در اختیار داشتن یک پوینده OBD، به راحتی همه اطلاعات حسگرها و عملگردهای متصل به سیستم الکترونیکی خودرو را مشاهده نمایند [۲۹].

### ۲-۴-۲ پروتکل SAE J1939

این پروتکل نیز مشابه پروتکل OBD2 برای استفاده در خودروها توسعه یافته است ولی با پیادهسازی امکانات اضافی در راستای اطمینانپذیری بالاتر، برای محیطهای مشکل خشن مناسب میباشد [۳۰].

### ۳-۴-۲ پروتکل CANOpen

پروتکل CANOpen توسط کارگروهی شامل تولیدکنندگان و کاربران موسوم به CiA پشتیبانی میشود که البته هر کاربر میتواند بسته به نیازش، مستقلا تغییراتی در پیادهسازی نهایی خود انجام دهد

\_

<sup>&</sup>lt;sup>1</sup> Application Layer

<sup>&</sup>lt;sup>2</sup> Can in Automation

[ $^{9}$ ]. همانطور که در شکل ۱-۱ نیز مشخص است، لایههای فیزیکی و لینک داده (مطابق مدل مرجع (OSI) توسط استاندارد باس CAN مشخص می شود و هدف CANOpen، پیاده سازی لایههای بالایی است. به همین منظور، CANOpen توانایی مدیریت یک شبکه، ارتباط معنی دار بین گرهها و نظارت بر دستگاهها را به یک مجموعه دستگاه متصل از طریق باس CAN می افزاید [ $^{8}$ ]. بدین صورت، شکل ۲- دستگاهها را به یم استقرار این پروتکل در یک ارتباط باس CAN را به نمایش می گذارد.



شكل ٢-١٠: نمايش مدل لايهاي شبكهاي مبتني بر پروتكل CANOpen [٣٢]

به منظور ارسال و دریافت داده معنیدار، CANOpen دو مفهوم نوع داده و توالی بیتی را شرح می دهد. نوع داده ها می توانند اولیه یا ایستا (مانند اعداد یا متغیر بولین) و یا پیچیده (مانند زمان) باشند. سپس بر اساس نوع داده، کدگذاری آن انجام شده و در توالیهای بیتی هشتی (یک بایتی) به مقصد ارسال می شوند. این انتقال از طریق آدرس دهی به هر گره انجام می شود که در حالت استفاده از CAN ارسال می شوند. این انتقال از طریق آدرس دهی برابر ۱۲۷ می باشد و هر گره دارای یک آدرس منحصر به فرد 1.0A می باشد. هر بسته ارسالی نیز یک شی ارتباطی نام دارد که بسته به کاربرد آن در شبکه CANOpen می باشد. هر بسته ارسالی نیز یک شی ارتباطی نام دارد که بسته به کاربرد آن در شبکه 1.0A

<sup>2</sup> Bit sequences

<sup>&</sup>lt;sup>1</sup> Data Type

<sup>&</sup>lt;sup>3</sup> Communication Object

انواع مختلفی شی ارتباطی وجود دارد که در جدول ۲-۵ مشخص شده است [۳۳]. همچنین قاب داده پیامهای پروتکل CANOpen در جدول ۲-۶ قابل مشاهده میباشد. از آنجایی که قاب داده CANOpen میتواند حداکثر ۸ بایت داده را منتقل کند، عملکرد قطعه قطعه کردن یک محموله ارسالی به چندین قاب مختلف برای ارسال روی باس CAN (و یا CAN FD) نیز پیادهسازی شده است [۳۲].

جدول ۲-۴: اشیا ارتباطی پروتکل CANOpen [۳۳].

| شی ار تباطی             | وظيفه                                                           |
|-------------------------|-----------------------------------------------------------------|
| PDO                     | ارسال داده مورد نظر کاربر.                                      |
| SDO                     | ارسال اطلاعات پیکربندی شبکه و دستگاهها.                         |
| NMT node monitoring     | بررسی صحت کارکرد یک دستگاه در شبکه از طریق پروتکل ضربان قلب'.   |
| LSS                     | پیکربندی شبکه، مانند تغییر نرخ داده.                            |
| NMT node control        | تغییر وظعیت شبکه برای دستگاهها، مانند اتصال یا قطع شدن از شبکه. |
| Global failsafe command | ارسال پیامهایی با اولویت بسیار بالا به منظور حفظ امنیت شبکه.    |
| Sync                    | همگامسازی شبکه                                                  |
| Emergency               | ارسال پیامهایی با اولویت بسیار بالا مانند خرابی یک دستگاه.      |
| TimeStamp               | ارسال زمان.                                                     |

جدول ۲-۵: اجزا یک بسته ارسالی توسط CANOpen روی بستر CAN 1.0 [۳۳].

|     | Function code | Node ID | Remote<br>Transmission<br>Request | Data<br>length | Data        |
|-----|---------------|---------|-----------------------------------|----------------|-------------|
| طول | ۴ بیت         | ۷ بیت   | ۱ بیت                             | ۴ بیت          | ۰ تا ۸ بایت |

-

<sup>&</sup>lt;sup>1</sup> Heartbeat protocol

مفهوم کلیدی دیگری که در پروتکل میباشد. در دیکشنری اشیاء، تمام دادههای قابل ارسال و یا دریافت (اشیاء) هسته مرکزی این پروتکل میباشد. در دیکشنری اشیاء، تمام دادههای قابل ارسال و یا دریافت (اشیاء) شبکه ثبت میشوند و از طریق یک اندیس ۱۶ بیتی قابل دسترسی هستند. این اشیاء ثبت شده میتوانند ثابت و یا متغیر باشند، ولی همواره به صورت استاندارد، برخی اشیاء خاص باید در این دیکشنری ثبت شده باشند. در نهایت، میتوان از این دیکشنری برای درخواست و یا ارسال دادهای مشخص تنها از طریق دانستن مقدار اندیس آن اقدام نمود [۳۲]. جدول ۲-۷، نوع دادههای موجود در دیکشنری اشیاء را نشان میدهد.

جدول ۲-۶: اندیس و نوع اشیاء موجود در دیکشنری اشیاء [۳۲].

| نوع داده                             | اندیس شی (بر مبنای ۸) |
|--------------------------------------|-----------------------|
| رزرو شده                             | 0000                  |
| دادههای ایستا                        | 0001-001F             |
| دادههایی با نوع پیچیده               | 0020-003F             |
| دادههای مختص تولیدکننده              | 0040-005F             |
| دادههای ایستا مربوط به وضعیت دستگاه  | 0060-007F             |
| دادههای پیچیده مربوط به وضعیت دستگاه | 0080-009F             |
| رزرو شده                             | 00A0-0FFF             |
| دادههای مختص شبکه                    | 1000-1FFF             |
| دادههای مختص تولیدکننده دستگاه       | 2000-5FFF             |
| دادههای استاندارد دستگاه             | 6000-9FFF             |
| دادههای رزرو شده                     | A000-FFFF             |

<sup>&</sup>lt;sup>1</sup> Object Dictionary

فصل سوم طراحی و پیادهسازی ارتباطات

# طراحی و پیادهسازی ارتباطات

## ۱-۳- اهداف و ساختار کلی

هدف این پروژه، پیادهسازی یک ارتباط مبتنی بر باسهای CAN FD و CAN FD است که از طریق یک میکروکنترلر و یک FPGA محقق می شود. در گام اول، یک ارتباط دو طرفه بین دو دستگاه از طریق CAN ایجاد شده و علاوه بر این ارتباط دو طرفه، یک ارتباط از طریق باس CAN FD درون FPGA نیز پیادهسازی خواهد شد و تلاش شده است که این ارتباطات با پروتکل لایه کاربرد CANOpen سازگاری داشته باشند. خروجی نهایی این پیادهسازی، یک سیستم ارتباطی مناسب برای سیستمهای نهفته در کاربردهای متفاوت است و از انجایی دو پیادهسازی مجزا انجام میشوند (پیادهسازی نرمافزاری در سطح میکروکنترلر و پیادهسازی سختافزاری در سطح FPGA)، نتایج این طرح میتواند برای کاربردهای زیادی مفید واقع شوند. تصویر کلی سیستم پیاده شده در شکل ۱-۱ قابل مشاهده میباشد. همانطور که در فصل ۲ اشاره شد، لایه فیزیکی باس CAN از دو سیم درهم تنیده تشکیل شده است که سیگنال انتقالی را به صورت ولتاژ تفاضلی مخابره می کنند [۱۰]. با توجه به ماهیت دیجیتال قطعات مورد استفاده مانند میکروکنترلر، امکان تولید سیگنال تفاضلی آنالوگ مورد نظر بدون استفاده از ادوات جانبی وجود ندارد. بنابراین، به منظور تولید دو سیگنال CAN\_H و CAN\_L نیاز به دستگاه فرستنده-گیرندهای هست که این عملیات را انجام دهد. شکل ۳-۱ نمودار بلوکی کلی یک باس CAN با استفاده از فرستنده-گیرنده را نشان می دهد. البته که استفاده از فرستنده-گیرنده تنها راه استفاده از باس CAN در قطعات دیجیتال نمی باشد، بلکه راهکار دیگری نیز پیشنهاد شده است که در شکل ۳-۲ مشاهده می شود. استفاده از این روش پیشنهاد نمی شود چرا که در عمل برخی از خواص باس CAN را زیر سوال برده و همچنین حداکثر طول موثر باس را به شدت کاهش داده به طوری که تنها برای کاربرهای روی برد مناسب میباشد [75].



. [74] با استفاده از فرستنده –گیرنده ([74] با استفاده از فرستنده –گیرنده ([74]



شکل ۲-۳: باس CAN بدون استفاده از فرستنده –گیرنده [ $^{2}$ ].

## ۲-۳- قطعات مورد استفاده

در راستای پیاده سازی این پروژه، قطعاتی برای راهاندازی سیستم ارتباطی نیاز است که برای این طرح، از قطعات زیر استفاده شده است:

- برد Arduino Due به عنوان میکروکنترلر
  - برد Ava3S400 به عنوان
    - برد فرستنده  *گی*رنده TJA1050
    - سیم جامیر متداول برای اتصالات

در ادامه مشخصات اجمالی هر یک از این قطعات بیان خواهد شد.

## ۲-۲-۳ برد Arduino Due

برد Arduino Due یک برد میکروکنترلر و ساخت شرکت Arduino میباشد. پردازنده موجود روی این Arduino میباشد. پردازنده موجود روی این برد Arduino است که از معماری ۳۲ بیتی Arduino است که از معماری آن Arduino میباشد. بر خلاف دیگر بردهای Arduino (که عموما دارای معماری AVR هستند) ولتاژ کاری این برد برابر ۳.۳۷ بوده و توان لازم از طریق کابل Micro-USB تامین میشود. سایر ویژگیهای کلیدی این برد عبارتند از:

- حافظه Flash با ظرفیت ۵۱۲ کیلوبایت
- حافظه SRAM با ظرفیت ۹۶ کیلوبایت
- ۵۴ پین ورودی-خروجی عمومی دیجیتال
- ۱۲ پین ورودی-خروجی آنالوگ (PWM)

\_

<sup>&</sup>lt;sup>1</sup> GPIO

- ۲ مبدل دیجیتال به آنالوگ ۱۲ بیتی
- کنترل کننده واسطهای I2C ،SPI و CAN •



شکل ۳-۳: برد Arduino Due از نمای بالا [۳۹].

### ۲-۲-۳ برد Ava3S400

برد Ava3S400 یک برد FPGA مبتنی بر FPGA مبتنی بر Xilinx Spartan XC3S400 ساخت شرکت رهپویان علم و صنعت آوا میباشد. این FPGA دارای ۴۸۶۴ سلول منطقی، ۵۶ کیلوبایت حافظه RAM توضیع شده، BRAM و حداکثر ۲۶۴ ورودی-خروجی میباشد. برنامه ریزی این FPGA از طریق واسط JTAG امکان پذیر میباشد [۳۷]. برد مورد نظر نیز امکانات متنوعی برای مدیریت ورودی-خروجیها نظیر ۱۶ سوئیچ، ۱۶ عدد LED، درگاه USB و همچنین یک اسیلاتور با فرکانس کاری خروجیها نظیر ۱۶ سوئیچ، ۱۶ عدد طریق محیط توسعه FPGA قابل برنامه ریزی و استفاده میباشند [۳۸].



شكل ٣-٣: تصوير برد Ava3S400 و ادوات جانبي آن [٣٨].

### ۳-۲-۳ برد فرستنده *- گی*رنده TJA1050

TJA 1050 یک فرستنده-گیرنده باس CAN است که توسط شرکت NXP تولید شده است. این فرستنده گیرنده کاملا با استاندارد ISO1898 سازگار بوده و وظیفهی اصلی آن این است که سیگنالهای تفاضلی CAN\_H و CAN\_L را دریافت کرده و طبق مشخصات پروتکل CAN، این دو یک سیگنال سریال تولید کرده که داده منتقل شده را نمایش میدهد. حداکثر نرخ بیتی انتقال برای این فرستنده-گیرنده طبق مشخصات تولیدکننده برابر ۱Mbps میباشد [۳۹].



شكل ٣-۵: برد شامل فرستنده - گيرنده TJA 1050

همانطور که ذکر شد، عملکرد این برد مبتنی بر تراشه فرستنده-گیرنده TJA 1050 میباشد. شکل ۳- ۶، شماتیک این تراشه و جدول ۳-۱ وظایف پایههای این تراشه را نشان میدهد.



.[ $^{\P q}$ ] نمای بالا ( $^{\Pi q}$ ) از نمای بالا

جدول ۳-۱: توضیحات پایههای تراشه 1050 TJA  $[^{9}]$ 

| توضيحات                                         | عملكرد             | نماد پایه        | شماره پایه |
|-------------------------------------------------|--------------------|------------------|------------|
| مقادیر دریافتی از کنترلکننده CAN را دریافت کرده | خروجی ارسال داده   | TXD              | 1          |
| و روی باس ارسال مینماید.                        |                    |                  |            |
| -                                               | مرجع زمین تراشه    | GND              | ۲          |
| باید بین ۴.۷۵ تا ۵.۲۵ ولت باشد.                 | ولتاژ تغذيه تراشه  | $V_{CC}$         | ٣          |
| داده موجود روی باس را دریافت کرده و برای        | دریافت داده ورودی  | RXD              | ۴          |
| کنترلکننده CAN ارسال میکند.                     |                    |                  |            |
| -                                               | ولتاژ مرجع خروجى   | $V_{\text{ref}}$ | ۵          |
| مقداری بین صفر ولت تا $ m V_{CC}$ را میپذیرد.   | خط CAN_L باس       | CANL             | ۶          |
| مقداری بین صفر ولت تا $ m V_{CC}$ را میپذیرد.   | خط CAN_H باس       | CANH             | Y          |
| انتخاب بین دو حالت فعال و غیر فعال از طریق این  | انتخاب حالت عملكرد | S                | ٨          |

| پایه ممکن میشود. |  |
|------------------|--|
|------------------|--|

## ۳-۳- نرمافزارهای مورد استفاده

عمده توسعه این طرح توسط دو نرمافزار صورت گرفته است:

- Arduino IDE: این نرمافزار محیطی یکپارچه برای برنامهنویسی Arduino و بردهای مشابه به زبانهای C و ++ ک میباشد. علاوه بر تسهیل نوشتن و کامپایل نمودن کد، این نرمافزار در زمینه برنامهریزی بردها نیز کمک به سزایی میکند. یکی از مهمترین خواص این برنامه، مجرد ساختن کار کردن با ورودی-خروجیهای برد میباشد. به دلیل سازگاری بالا با بردهای ماختن کار کردن با ورودی کتابخانه برای این محیط برنامهنویسی تولید و ارائه شده است (۴۰ کار).
- Xilinx ISE: نرمافزار ISE محیطی جامع برای توسعه و پیادهسازی سختافزارهای برنامهپذیر Xilinx ISE: کرمافزار علاوه بر فراهم آوردن محیط (ASIC) و حتی CPLD ، FPGA) میباشد. این نرمافزار علاوه بر فراهم آوردن محیط برنامهنویسی برای زبانهای توصیف سختافزار (۱۰ قابلیتهای شبیهسازی نرمافزاری، سنتر و پیادهسازی، برنامهریزی سختافزار و همچنین تجزیه و تحلیل طرحها را ارائه میکند [۲۱]. البته در چند سال اخیر، نرمافزار Vivado شرکت Xilinx تقریبا جایگزین این نرمافزار شده است ویژگیهای بیشتری نیز برای استفاده طراحان فراهم ساخته است [۲۱]. بنابراین از ISE برای کار با FPGAها قدیمی تر شرکت Xilinx استفاده می شود.

\_

<sup>&</sup>lt;sup>1</sup> Hardware Description Language (HDL)

## ۳-۶- کتابخانههای مورد استفاده

در مراحل توسعه این طرح، از تعدادی کتابخانه نرمافزاری برای برنامهریزی میکروکنترلر و همچنین تعدادی IP Core برای پیادهسازی ساختافزاری FPGA استفاده شده است که ویژگیها و تواناییهای موارد قابل توجه بیان شده است.

#### ۲-۴-۳ کتابخانه Due CAN

کتابخانه Due CAN به صورت یک مجموعه متنباز است که توسط تعدادی توسعهدهنده به صورت عملکرد عمومی طراحی شده و در اختیار همگان قرار گرفته است. هدف اصلی این کتابخانه، پیادهسازی عملکرد عمومی باس CAN روی معماری پردازندههای SAM میباشد [۲۳].

پیاده سازی کلی این کتابخانه در یک لایه و به صورت شی گرایانه انجام شده است. در ادامه، توضیحات مختصر توابع کلیدی و انواع داده لازم به منظور کار با این کتابخانه ارائه شده است.

تابع (CAN شماره X با نرخ باد برابر استان المحدوم المن تابع در صورت موفقیت مقدار المحدوم المن تابع به محاسبه بخشهای زمانی (زمان بیتی) باس (CAN بر اساس مقدار می باشد. اساسی ترین عمل این تابع به محاسبه بخشهای زمانی (زمان بیتی) باس (CAN بر اساس مقدار نرخ باد ورودی می باشد. به عنوان مثال، اجرای تابع به صورت (Cano.init() مقدار ابازگردانی کرده و اجرای آن به صورت (Cano.init() نیز مقدار صفر را باز می گرداند. شکل V-V نمودارد بلوکی عملکردی این تابع را نمایش می دهد.

نوع داده CAN\_FRAME: این نوع داده یک ساختار ۲ برنامهنویسی بوده که شامل بخشهای قابل تغییر یک قاب CAN نظیر شناساگر (اولویت)، محموله داده و چندین بخش دیگر میباشد. بخشهای نظیر کد CRC و اندازه داده (بر اساس DLC) در هنگام ارسال بسته محاسبه می شود.

<sup>2</sup> Struct

<sup>&</sup>lt;sup>1</sup> Baud Rate

—نرخ باد —Baud Rate

# بافر ورودی Rx Buffer CAN Protocol یص پایههای -Controller بافر خروجی Tx Buffer خواندن مقادیر روی باس ∕—صفر در صورت ناتوانی در خواندن ∕—مقدار باس تا زمانی مشخص زمانسنج موجود در

uint32\_t CanX.init(int B)

شکل ۳-۷: نمودار بلوکی عملکردی تابع init.

set\_baudrate تابع

- نرخ باد Baud Rate-

كنترلكننده

تابع (uint32\_t CanX.watchFor: این تابع پینهای باس CAN شماره X را فعال کرده و در نتیجه، در ادامه می توان تمامی ترافیک انتقالی روی باس را مشاهده نمود. مقدار بازگشتی این تابع، آدرس محل شروع ذخیره پیامهای دریافتی روی کنترل کننده X میباشد. در صورت فرخوانی این تابع، هر پیام موجود روی باس CAN درون بافر ورودی $^{1}$  قرار گرفته و از طریق تابع cad قابل مشاهده خواهد بود. شکل ۳-۸ نمودار بلوکی عملکردی این تابع را نمایش میدهد.

uint32 t CanX.watchFor()



شکل ۳-۸: نمودار بلوکی عملکردی تابع watchFor.

<sup>&</sup>lt;sup>1</sup> Buffer

تابع (void CanX.read(\* FRAME) این تابع آخرین قاب پیام موجود روی بافر ورودی void CanX.read( بازیابی کرده و در ادامه می توان محتوای موجود را مورد بررسی قرار داد. قاب پیام دریافت، از طریق اشاره گر FRAME قابل دسترسی می باشد. شکل ۳-۹ نمودار بلوکی عملکردی این تابع را نمایش می دهد.

#### void CanX.read(\* FRAME)



شکل ۳-۹: نمودار بلوکی عملکردی تابع read.



شکل ۳-۱۰: نمودار بلوکی عملکردی تابع sendFrame.

تابع امکان غربال باین تابع امکان غربال است. wiint16\_t CanX.setRXFilter(int id, int mask, bool extended) و بایم را فراهم می کند. این غربال می تواند بر اساس شناساگر (ID)، محتوا (mask) و یا هر سه باشد. بنابراین از طریق این عملکرد، می توان از قابهای داده فاقد العمیت صرف نظر کرده و تنها به پردازش دادههای مهم پرداخت. خروجی این تابع، نشان می دهد که پیام دریافتی با غربال مشخص در چه آدرسی ذخیره شده است. عملکرد نهایی مانند تابع (wathcFor) می باشد، با این تفاوت که در هر زمانی قابل فراخوانی بوده و از طریق آن می توان مقدار غربال ها را تغییر داد.

تابع ()uint16\_t CanX.available: با فراخوانی این تابع، ثبات FIFO ورودی کنترلکننده بازگردانده می شود. بررسی شده و در صورت وجود پیام، تعداد پیامهای موجود بازگردانده می شود.

تابع ()uint32\_t CanX.beginAutoSpeed: باس را با نرخهای بیتی مختلف شنود کرده (از طریق تابع قاند از طریق نامند نامند استفالی با یکی از سرعتهای مشخص شده تشخیص دهد، مقدار آن را بازگردانی میکند [۴۳].

#### liteCAN IP Core - Y-Y-Y

هسته liteCAN توسط جامعه متن باز توسعه یافته است و توسعه آن در دانشگاه USTC کشور چین آغاز شده است. هدف این IP Core پیاده سازی جامعه تمامی ویژگیهای باس CAN می باشد. بنابراین،

محدودیتهای روی ارسال قابهای پیام CAN اعمال شده است، به طور مثال، محموله ارسالی حداکثر معدودیتهای روی ارسال قابهای پیام IP Core این Soft به صورت Soft میباشد و در سطح انتقال ثبات و با استفاده از زبان System Verilog نوشته شده است  $[\xi \xi]$ . به همین علت، به منظور استفاده از آن در این پروژه، کدهای موجود این هسته به زبان Verilog بازنویسی شدهاند.

پیاده سازی این IP Core در چهار لایه انجام شده است. توضیحات و عملکرد هر لایه از بالا به پایین در ادامه بیان شده است:

لایه اول (لایه TOP): این لایه مسئول بر قراری اتصالات میان لایه فیزیکی FPGA و لایههای پایین تر میباشد. عملکردهایی مانند مدیریت کلاک، بررسی صحت ورودی و خروجیها در این لایه به انجام میرسند.

لایه دوم (لایه FIFO): این لایه مسئول مدیریت بافرهای FIFO ورودی و خروجی میباشد.

لایه سوم (لایه Packet): وظیفه این لایه، تولید قابهای خروجی و تفسیر قابهای ورودی میباشد و همچنین ارسال و دریافت قابها از بافرهای FIFO میباشد.

لایه چهارم (لایه BIT): این لایه، پایینترین لایه هسته ذکر شده میباشد و وظیفهی آن، ارسال و دریافت پیامهای لایهی بالاتر در سطح بیت میباشد [٤٤].

به منظور استفاده از قابلیتهای این هسته، نیاز است که با واسطهای ارائه شده در بالاترین سطح کار شود. به همین منظور، درگاه ٔهای مهم این لایه در ادامه شرح داده شدهاند:

LOCAL\_ID: مقدار شناساگر گره را مشخص می کند.

default\_c\_PTS: تعداد كوانتوم زمان بخش PROP\_SEG را تعيين مىكند.

default\_c\_PBS1: تعداد كوانتوم زمان بخش PHASE\_SEG 1 را تعيين ميكند.

<sup>&</sup>lt;sup>1</sup> Register Transfer Level

<sup>&</sup>lt;sup>2</sup> Port

default\_c\_PBS2: تعداد كوانتوم زمان بخش PHASE\_SEG 2 را تعيين مي كند.

rstn: سیگنال بازنشانی سیستمی را دریافت می کند.

CLK: سیگنال کلاک سیستمی را دریافت می کند.

can\_rx: سیگنال دریافت داده باس CAN میباشد.

can\_tx: سیگنال ارسال داده باس CAN میباشد.

tx\_valid: مشخص می کند که گره می خواهد دادهای ارسال کند یا خیر.

tx\_data: داده ارسالی روی باس CAN را مشخص مینماید.

rx\_valid: مشخص می کند که آیا گره در حال دریافت دادهای صحیح است یا خیر.

این درگاه قرار می گیرد  $[\xi \xi]$ . داده ی دریافت شده از باس روی این درگاه قرار می گیرد تعدید از باس روی این درگاه قرار می گیرد از درگاه قرار می گیرد از باس روی این درگاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه قرار می گیرد از باس روی این در گاه تا در می گیرد از باس روی این در گاه تا در می گیرد از باس روی این در گاه تا در گاه تا در آن در گاه تا در آن در گاه تا در گا

#### CTU CAN FD IP Core - 4-4-4

این IP Core نیز یک هسته مالکیت معنوی متن باز بوده که توسط متخصصان دانشگاه IP Core نیز IP Core توسعه یافته است. این هسته یک هسته Soft است که تماما توسط زیان Technical University نوشته شده است و هدف آن، مطابقت کامل با استاندارد CAN FD میباشد. تعداد بایت داده ارسالی در هر فریم طبق استاندارد میتواند تا ۶۴ بایت باشد. علاوه بر قابلیتهای CAN FD، این هسته از باس APB نیز پشتیبانی میکند؛ بنابراین به منظور استفاده از این هسته، باید از طریق APB با آن ارتباط برقرار نموده و طبیعتا از قابلیتهای نظیر وقفه بهره برد [٥٤].

شکل ۱۱-۳ نمودار بلوکی این هسته را نشان میدهد. همانطور که در این شکل پیداست، اصلی ترین بخش این IP Core هسته پروتکل CAN میباشد که مسئول پیاده سازی تمامی عملکردهای ذکر شده

<sup>&</sup>lt;sup>1</sup> Advanced Peripheral Bus

در لایه لینک داده CAN FD میباشد. ارتباط این بلوک با لایه فیزیکی از طریق نمونه گیر باس انجام میشود که مسئول خواندن و یا نوشتن اطلاعات سریال دریافتی از باس میباشد [57].

در سمت دیگر هسته پروتکل CAN FD، اجزاء پردازش پیامهای ارسالی و یا دریافتی قرار دارد. در صورت تشخیص رسیدن پیام در هسته پروتکل، نخست از غربالهای قاب  $^{7}$  عبور کرده و در صورتی که با آنها مطابقت داشت، به بافر ورودی ارسال می شود که توسط حافظه قابل خواندن است. در صورت ایجاد دستور ارسال پیام نیز پیام ارسالی نخست در بافرهای خروجی قرار می گیرد. سپس با استفاده از عملکرد FIFO بلوک داور، تشخیص داده می شود که پیام قابل ارسال است یا خیر. در ادامه نیز پیامها به صورت  $^{5}$ از بافر خارج شده و روی باس قرار می گیرند  $^{5}$ ا.



شكل ٣-١١: نمودار بلوكي هسته CTU CAN FD [٤٦] [٤٦]

به منظور استفاده از قابلیتهای این هسته، نیاز است که با واسطهای ارائه شده در بالاترین سطح (ماژول CAN\_APB\_TOP) کار شود. به همین منظور، در گاههای مهم این لایه در ادامه شرح داده شدهاند:

aclk: سیگنال کلاک سیستمی را دریافت میکند.

arstn: سیگنال بازنشانی سیستمی را دریافت می کند.

CAN\_rx: سیگنال دریافت داده باس CAN FD میباشد.

<sup>&</sup>lt;sup>1</sup> Bus Sampler

<sup>&</sup>lt;sup>2</sup> Frame Filter

CAN FD: سیگنال ارسال داده باس CAN FD میباشد.

همچنین به منظور کنترلکننده با خارج، از واسط AMBA APB استفاده می شود. بنابراین علاوه بر درگاههای فوق، درگاههای واسط APB نظیر pwdata ،paddr و pwdata نیز درون این هسته تدارک دیده شدهاند [45].

### ۳-۵- پیادهسازی انجام شده

در این بخش، پیادهسازی انجام شده مورد بررسی قرار می گیرد. به دلیل ساختار طبیعی پروژه، این بررسی در دو بخش سختافزاری و نرمافزاری انجام خواهد شد. بخش سختافزاری، شامل توضیحات منابع، قطعات و اتصالات سختافزاری بود و بخش نرمافزاری نیز شامل توضیحات شیوه برنامهنویسی روی میکروکنترلر (از طریق زبانهای برنامهنویسی) و FPGA (از طریق زبانهای توصیف سختافزار) می باشد.

## ۳-۵-۳ ساختار سختافزاری

همانطور که ذکر شد، لایه فیزیکی باس CAN و همچنین CAN FD از دو رشته سیم تشکیل شده است که سیگنال مورد انتقال را به صورت تفاضلی مخابره میکنند. بنابراین برای ایجاد این باس خطی، دو رشته سیم در نظر گرفته میشود که البته مشابه با اغلب باسهای تفاضلی، نیازمند مقاومت خاتمه آنز میباشد. در ادامه به منظور ایجاد اتصال بین باس و بردهای پردازشی، یک فرستنده-گیرنده TJA نیز میباشد. در ادامه به منظور ایجاد اتصال بین باس و بردهای پردازشی، یک فرستنده وظیفه آن، تبدیل سیگنالهای تفاضلی به سیگنال سریال قابل دریافت و پردازش روی بردها میباشد.

اتصالات در لایه ورودی-خروجی بردها نیز ساختار خود را دارد. در سمت برد AVS3S400، می توان از هریک از پینهای موجود استفاده نمود، البته به این شرط که در زمان سنتز و پیادهسازی کد توصیف سختافزار روی این برد، پینهای مورد نظر به عنوان مراجع اتصال CAN در نظر گرفته شوند. برد

<sup>&</sup>lt;sup>1</sup> Termination Resistor

این برد (وی این برد Arduino Due نیز طبیعتا انعطافپذیری به مراتب پایین تری داشته و اتصال باس CAN روی این برد (وی این برد باید از طریق یکی از دو درگاه CAN0 (پینهای ۶۸ و ۶۹) و یا CAN1 (پینهای ۵۳ و ۶۶) انجام شود. دو پین اتصال مورد استفاده روی بردهای پردازشی، در قالب پینهای اتصال سریال Rx و Rx بوده که به ترتیب وظیفه ارسال و دریافت سیگنال به فرستنده–گیرنده را بر عهده دارند.

هدف اصلی در این پروژه برقراری ارتباط از طریق یک باس CAN-FD بین یک میکروکنترلر و یک FPGA بوده است که به دلیل عدم امکان تهیه برد میکروکنترلر با CAN-FD سناریوهای دیگری در نظر گرفته شده است که در ادامه تشریح خواهد شد.

در این پروژه، دو پیکربندی متفاوت پیادهسازی شده است و هر یک مورد بررسی و ارزیابی قرار گرفتهاند. در پیکربندی اول، ارتباطی بین میکروکنترلر و برد FPGA از طریق باس CAN ایجاد شده است و درون FPGA نیز دو هسته باس CAN FD قرار گرفته است که داده دریافتی از واسط CAN بین آنها منتقل میشود. شکل ۳-۱۲ شماتیک سختافزار و اتصالات انجام شده در پیکربندی اول را نشان داده و شکل ۳-۱۲ نیز نمودار توالی این پیکربندی را نشان میدهد.

پیکربندی دوم، با هدف ارزیابی جامعتر باس CAN FD پیادهسازی شده است. به همین منظور، دو کنترلکننده باس CAN FD روی FPGA قرار گرفتهاند و درگاههای انتقال و دریافت هریک روی پایههای ورودی-خروجی برد FPGA قرار گرفته است. در پایان نیز ارتباط دو هسته CAN FD از طریق فرستنده-گیرنده TJA1050 برقرار شده است و بررسیهای لازم روی این معماری ارتباطی انجام شدهاند. شکل ۳-۱۴ شماتیک سختافزار و اتصالات انجام شده در پیکربندی دوم را به تصویر میکشد. همچنین شکل ۳-۱۵ نیز نمودار توالی این پیکربندی را نشان میدهد.

<sup>&</sup>lt;sup>1</sup> Sequence Diagram



شکل ۳-۱۲: شماتیک ساختار سختافزاری پیکربندی اول.



شکل ۳-۱۳: نمودار توالی پیکربندی اول.



شکل ۳-۱۴: شماتیک ساختار سختافزاری پیکربندی دوم.



شکل ۳-۱۵: نمودار توالی پیکربندی دوم.

### ۳-۵-۳- ساختار نرمافزاری

پیادهسازی نرمافزاری این طرح از دو بخش مجزا ولی مرتبط تشکیل میشود که هر یک بخشی از ارتباط را تشکیل میدهند: پیادهسازی با زبان توصیف سختافزار به منظور راهاندازی FPGA و همچنین پیادهسازی با زبانهای نرمافزاری به منظور راهاندازی میکروکنترلر. با وجود تشابه عملکرد این دو بخش، طراحی و کد کاملا متفاوتی دارند. در FPGA، کد مورد نظر به صورت ترکیبی از دو زبان توصیف سختافزار VHDL و Verilog و در میکروکنترلر، کد از طریق زبان ++C/C نوشته شده است. همانطور که ذکر شد، پیادهسازی میکروکنترلر تنها مختص پیکربندی اول است و پیکربندی دوم تنها بر FPGA پیادهسازی شده است.

طراحی هر دو بخش پیادهسازی به صورت معماری لایهای بوده است که این معماری به طور کلی از دو لایه کاربرد و لایه اتصال تشکیل شده است. لایه کاربرد، لایه بالاتر و محل پیادهسازی قابلیتهای CANOpen میباشد و لایه اتصال، مسئول ارسال و دریافت قابهای پروتکل CANOpen از طریق ارتباط فیزیکی موجود و به کمک کتابخانههای نرمافزاری میباشد.

لایه کاربرد در میکروکنترلر در قالب یک کتابخانه با نام CANOpen.h طراحی شده است. واسطهای اصلی ارائه شده توسط این کتابخانه عبارتند از:

(\* CO\_FRAME\* send\_co\_frame(char :این تابع رشته پیام دلخواه را از طریق ورودی دریافت :CO\_FRAME\* send\_co\_frame(char کرده و پیام را به صورت قابهای پروتکل CANOpen در میآورد. در پایان اجرا نیز پیامهای تولیدی را باز می گرداند.

(char \* receive\_co\_frame(CO\_FRAME\*) این تابع نیز در صورت فراخوانی، در انتظار یک پیام در انتظار یک پیام مینشیند و اگر پیامی مطابق پروتکل CANOpen دریافت کند، محموله آن محاسبه کرده و بازگردانی میکند.

در بطن کتابخانه طراحی شده CANOpen.h، عملکردهای لازم برای تولید یک پیام مطابق پروتکل در بطن کتابخانه طراحی شده است. مهمترین عملکردهای انجام شده شامل CANOpen

قطعهبندی محموله، محاسبه بخشهای قاب محموله، قراردادن هر قطعه داخل قاب مربوطه و در پایان ارسال از طریق توابع لایه اتصال میشود. لایه اتصال، به کمک کتابخانههای موجود توسعه داده شده است که توضیحات مربوطه در بند ۴-۳- ارائه شد. لازم به ذکر است که این پیادهسازی احمالی از CANOpen و تمامی ویژگیهای آن نبوده و تنها قابلیتهای اساسی دوجه پیادهسازی کاملی از CANOpen و دریافت داده پیادهسازی شدهاند.

در سمت دیگر پیادهسازی یعنی راهاندازی FPGA، دو پیکربندی پیادهسازی شده است. در پیکربندی اول، عملکردی مشابه میکروکنترلر پیادهسازی شده است؛ با این تفاوت که در اینجا بجای تولید کتابخانه نرمافزاری، ماژولهای سختافزاری به منظور ایجاد ارتباط CAN FD و همچنین CAN FD طراحی شدهاند. تلاش شده است که کد توصیف سختافزار تا حد امکان مشابه کد نرمافزاری بوده و دارای اسامی و عملکرد یکسانی باشد. در لایه اتصال FPGA نیز از طریق هستههای معرفی شده در بند ۴-۳- ارتباط عملکرد یکسانی باشد. در لایه اتصال داده صورت میپذیرد. CAN FD نیز به صورت داخلی درون FPGA پیادهسازی شده است و ارتباط آن داخلی است.

در پیکربندی دوم، تنها ارتباط CAN FD پیادهسازی شده است و تفاوت آن با پیکربندی اول، ایجاد درگاههای کنترلکنندههای CAN FD روی پایههای FPGA است که امکان بررسی دقیق تر باس درگاههای کنترلکنندههای برای براتجه به انعطاف پذیری طراحی FPGA، می توان از هر پایه دلخواهی برای درگاههای ورودی و خروجی دو کنترل کننده استفاده نمود. در ادامه نیز این ارتباط با متغیرهای زمانی مختلف قرار گرفته است.

مقدار نرخ بیت در حالت کلی پیکربندی اول (باس CAN بین دو برد پردازشی) نیز با توجه به کاربردهای متداول پروتکل CANOpen، برابر مقدار ۱۲۵ Kbps قرار داده شده است. البته که در هردو پیکربندی، ارتباط با سرعتهای متداول بالاتر و همچنین نرخهای بیتی بالاتر از Mbps نیز پیادهسازی شده و مورد بررسی و ارزیابی قرار گرفته است. به همین منظور، مقادیر زمانی مطابق جدول ۲-۳ محاسبه

و انتخاب شدهاند. لازم به ذکر است که فرکانس کلاک پایه برد FPGA برابر ۴۰ MHz و برای میکروکنترلر برابر ۸۴ MHz میباشد.

جدول ۳-۲: مقادیر زمانی محاسبه شده برای ارتباط صحیح دو برد تحت باس CAN FD و CAN FD.

| ۳۰۰۰ Kbps<br>(فقط باس | ۲۰۰۰ Kbps<br>(فقط باس | \··· Kbps  | ۵۰۰ Kbps   | 174 Kbps   | نرخ بیت                                  |
|-----------------------|-----------------------|------------|------------|------------|------------------------------------------|
| (CAN FD               | (CAN FD               |            |            |            |                                          |
| -                     | <del>-</del>          | ۶          | ۲٠         | ۸۳         | عامل<br>Prescaler<br>برای<br>میکروکنترلر |
| ١                     | ۲                     | ٣          | 1.         | ۴۰         | عامل<br>Prescaler<br>برای FPGA           |
| یک کوانتوم            | یک کوانتوم            | یک کوانتوم | یک کوانتوم | یک کوانتوم | SYNC_SE                                  |
| زمانی                 | زمانی                 | زمانی      | زمانی      | زمانی      | G                                        |
| سه کوانتوم            | سه کوانتوم            | دو کوانتوم | دو کوانتوم | دو کوانتوم | PROP_SE                                  |
| زمانی                 | زمانی                 | زمانی      | زمانی      | زمانی      | G                                        |
| سه کوانتوم            | سه کوانتوم            | سه کوانتوم | یک کوانتوم | یک کوانتوم | PHASE_S                                  |
| زمانی                 | زمانی                 | زمانی      | زمانی      | زمانی      | EG 1                                     |
| چهار کوانتوم          | چهار کوانتوم          | سه کوانتوم | دو کوانتوم | دو کوانتوم | PHASE_S                                  |
| زمانی                 | زمانی                 | زمانی      | زمانی      | زمانی      | EG 2                                     |



شکل ۳–۱۶: شماتیک RTL ماژول سطح بالا در FPGA (پیکربندی اول).



شکل  $^{-1}$ : شماتیک  $^{-1}$  ماژول سطح بالا در  $^{-1}$  (پیکربندی دوم).

فصل چهارم ارزیابی ارتباطات

## ارزیابی ارتباطات

## ٤-١- صحت عملكرد

در نخستین گام ارزیابی پیادهسازی انجام شده، نیاز است که صحت عملکرد ارتباطات ایجاد شده مورد بررسی قرار گیرد. به همین منظور، نخست هر یک از بردها به صورت جداگانه مورد آزمایش قرار گرفتهاند. گرفتهاند و سپس پیکربندیهای پیادهسازی شده به صورت یکپارچه مورد آزمایش قرار گرفتهاند.

در راستای بررسی عملکرد پیکربندیهای برد FPGA میتوان از testbench نرمافزاری استفاده نمود. در این بخش، یک مورد testbench نوشتیم که روند آن بدین صورت است که دو مورد ماژول سطح بالای درون محیط آزمون نمونهسازی شده و با ارسال و دریافت چندین بسته به صورت متناوب روی خطوط باس، صحت ارتباط بررسی میشود. با توجه به سادگی و به طبع انعطاف عملکرد این آزمون، میتوان از آن برای هر دو پیکربندی پیادهسازی شده روی FPGA استفاده نمود. شکل ۱-۲ نمایی از بخش کوچکی از این آزمون نرمافزاری را به نمایش میگذارد.

در سمت دیگر ارتباط یعنی پیادهسازی میکروکنترلر نیز عملکرد کلی مورد ارزیابی قرار گرفته است. به همین منظور، یک آزمون نوشته شده است که بر طبق آن، دادهای یکسان از کنترلکننده باس CAN اول به دیگری ارسال میشود و همین عملکرد در کنترلکننده دوم نیز رخ میدهد. در پایان نیز صورت دریافت موفق داده در هر کنترلکننده، محتوای پیام دریافتی از طریق ارتباط سریال (ارتباط TART دریافت موفق داده در هر کنترلکننده، محتوای پیام دریافتی از طریق ارتباط سریال (ارتباط TART برای سیستم برنامهنویسی ارسال شده و روی صفحه چاپ میشود. شکل ۲-۴، شمای مدار این آزمون و شکل ۴-۲، شمان میدهد.

-

<sup>&</sup>lt;sup>1</sup> Instantiate



شکل ۴-۱: شبیهسازی باس CAN روی FPGA. در این محدوده، کنترل کننده اول در حال نوشتن اطلاعات روی باس مشترک میباشد.



شکل ۴-۲: مدار آزمون کنترل کنندههای CAN میکروکنترلر.

```
COM6
با موفقیت راهاندازی شد. : CANO
با موفقیت راهاندازی شد. :CAN1
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CANO: ييام دريافت شد - ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CANO: پیام دریافت شد – ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CANO: پیام دریافت شد - ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CANO: پیام دریافت شد – ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CANO: پیام دریافت شد - ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CANO: پیام دریافت شد – ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CANO: پیام دریافت شد - ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CANO: پیام دریافت شد - ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CANO: پيام دريافت شد – ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CANO: پيام دريافت شد – ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
CAN1: پیام دریافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CAN0: پیام دریافت شد - ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
CAN1: پيام دريافت شد - ID: 18FAFE80 Length: 8 Data: 1 2 3 4 5 6 7 8
CANO: پیام دریافت شد - ID: 18FAFD81 Length: 8 Data: F E D C C B A 8
```

شكل ۴-۳: نتيجه آزمون باس CAN روى ميكروكنترلر.

در گام آخر سنجش صحت عملکرد، کلیت پیادهسازی هر دو پیکربندی به صورت یکپارچه مورد آزمایش قرار گرفت. به همین منظور، آزمونی در دل کدهای پیادهسازی گنجانیده شد که طبق آن، دادهها به صورت متناوب توسط هر کنترلکننده CAN ارسال میشوند. در سمت میکروکنترلر، موفقیت این ارسال و دریافت از طریق چاپ رو کامپیوتر میزبان بررسی میشود. در سمت FPGA نیز این موضوع از طریق کنترل دیودهای نوری موجود روی برد FPGA صورت گرفت؛ بدین صورت که ارسال و یا دریافت پیام از طریق دیودهای مشخص اعلام شده و همچنین در صورت دریافت داده، مقدار عددی آن روی دیودهای نوری قابل مشاهده میباشد. شکل ۴-۴ نیز شمای کلی این مدار در حین کار را به نمایش میگذارد. برای سنجش عملکرد پیکربندی دوم پیادهسازی نیز از روشی مشابه استفاده شده است و تنها تفاوت آن با شکل ۴-۴، عدم وجود میکروکنترلر و بازگشتی بودن باس CAN از دو پایه FPGA به دو پایه دیگر میباشد.



.CAN FD و CAN المكل  $^+$ : مدار بررسی عملكرد ارتباطهای  $^+$ 

# ۶-۲- میزان بهرهوری از منابع

مرحله دیگر ارزیابی، بررسی میزان منابع مصرفی طراحی در هر دو پیکربندی میباشد. به همین منظور، میران استفاده از سختافزار در میکروکنترلر و همچنین FPGA ارائه شدهاند. در میکروکنترلر، مهمترین میزان استفاده از سختافزار در میکروکنترلر و همچنین Flash ارائه شدهاند. در میکروکنترلر، مهمترین منبع موجود، حافظه flash میباشد که طبق اطلاعیه نرمافزار ۵۲۵ کیلوبایت حافظه در دسترس). همانطور Flash مورد استفاده قرار گرفته است (۱۳.۹ کیلوبایت از ۵۲۵ کیلوبایت حافظه در دسترس). همانطور که مشخص میباشد، حافظه ناچیزی برای پیادهسازی این طرح استفاده شده است. در مورد FPGA نیز میزان استفاده از بلوکهای منطقی موجود از طریق نرمافزار Xilinx ISE استخراج شده است و برای پیکربندی اول و دوم به ترتیب در جداول 4-1 و 4-7 قابل مشاهده هستند. در این زمینه نیز همانطور

که قابل مشاهده میباشد، پیاده سازی انجام شده بهینگی مناسبی داشته و درصد کمی از منابع سختافزاری FPGA را اشغال مینماید.

جدول ۴-۱: میزان استفاده از منابع سختافزاری در پیکربندی اول.

| Device Utilization Summary                     |      |           |             |         |
|------------------------------------------------|------|-----------|-------------|---------|
| Logic Utilization                              | Used | Available | Utilization | Note(s) |
| Number of Slice Flip Flops                     | 178  | 7,168     | 2%          |         |
| Number of 4 input LUTs                         | 307  | 7,168     | 4%          |         |
| Number of occupied Slices                      | 163  | 3,584     | 4%          |         |
| Number of Slices containing only related logic | 163  | 163       | 100%        |         |
| Number of Slices containing unrelated logic    | 0    | 163       | 0%          |         |
| Total Number of 4 input LUTs                   | 307  | 7,168     | 4%          |         |
| Number used as logic                           | 306  |           |             |         |
| Number used as a route-thru                    | 301  |           |             |         |
| Number of bonded IOBs                          | 20   | 141       | 14%         |         |
| Number of BUFGMUXs                             | 2    | 8         | 25%         |         |
| Average Fanout of Non-Clock Nets               | 3.20 |           |             |         |

جدول ۴-۲: میزان استفاده از منابع سختافزاری در پیکربندی دوم.

| Device Utilization Summary                     |      |           |             |         |  |
|------------------------------------------------|------|-----------|-------------|---------|--|
| Logic Utilization                              | Used | Available | Utilization | Note(s) |  |
| Number of Slice Flip Flops                     | 152  | 7,168     | 2%          |         |  |
| Number of 4 input LUTs                         | 173  | 7,168     | 2%          |         |  |
| Number of occupied Slices                      | 159  | 3,584     | 4%          |         |  |
| Number of Slices containing only related logic | 159  | 159       | 100%        |         |  |
| Number of Slices containing unrelated logic    | 0    | 159       | 0%          |         |  |
| Total Number of 4 input LUTs                   | 299  | 7,168     | 4%          |         |  |
| Number used as logic                           | 173  |           |             |         |  |
| Number used as a route-thru                    | 126  |           |             |         |  |
| Number of bonded <u>IOBs</u>                   | 12   | 141       | 8%          |         |  |
| Number of BUFGMUXs                             | 2    | 8         | 25%         |         |  |
| Average Fanout of Non-Clock Nets               | 3.10 |           |             |         |  |

# ارزیابی و مقاومت باس $^{*-}$

باس CAN از ابتدا با هدف استفاده صنعتی و به خصوص در صنعت خودرو طراحی شده است؛ به همین علت، طراحی آن از ابتدا به گونهای بوده است که تا حد امکان در مقابل نویزهای محیطی مقاوم باشد علت، طراحی آن از ابتدا به گونهای بوده است که تا حد امکان در مقابل نویزهای محیطی مقاوه دارای همین (۱۳]. باس CAN FD نیز به دلیل استفاده از لایه فیزیکی مشابه CAN، به صورت بالقوه دارای همین

ویژگیها میباشد [۲۸]، ولی به دلیل بهبود قابلیتهای تشخیص خطا در لایه لینک داده باس CAN ویژگیها میباشد [۲۸]. FD، توانایی این باس در تشخیص خطاهای احتمالی به مراتب بیشتر میباشد [۴۷].

به منظور ارزیابی طرح پیادهسازی شده، دو نوع آزمون برای هر دو پیکربندی ارائه شده است که هدف آن، بررسی میزان خطا و تاخیر باسهای CAN FD و CAN حر محیطهای طبیعی و همچنین در مواجه با نویز میباشد. در این آزمونها، هر یک از طرفین ارتباط به صورت مداوم و با فاصله زمانی حدود ۲۰ میلی ثانیه، بستهای روی باس ارسال می کنند. این بستههای دارای محمولهای عددی بوده که مقدار آن با هر ارسال افزایش می یابد و همچنین شناساگر هر یک از بستهها وابسته به گره ارسالی بوده و مقدار ثابت می باشد. این مساله باعث ایجاد ترافیکی بسیار بالا روی باس شده که می تواند تاخیر و همچنین امکان خطا را به صورت قابل توجهی افزایش دهد. در هر یک از این آزمونها، تعداد ۱۰۰۰۰ هزار بسته با نرخهای بیتی متفاوت روی باس ارسال شده است. محموله هر یک از بستهها دارای اندازهای ثابت ۶۴ برابر حداکثر اندازه قابل پذیرش برای یک بسته CAN است می باشد.

شکل ۴-۵، متوسط تاخیر ارسال و دریافت داده در هر دو پیکربندی را بر حسب تعداد بستههای ارسالی روی را در محیط بدون نویز نشان می دهد. در این آزمون، حتی پس از ارسال ۱۰۰۰۰ بسته نیز خطایی روی باسها ایجاد نشده بود. تاخیر محاسبه شده، از روی فاصله زمانی ارسال یک بسته تا دریافت آن در سمت گیرنده محاسبه شده است و بین مقادیر به دست آمده در دو سمت ارتباط، بیشترین آنها انتخاب شده است.

همچنین میزان تاخیر پیکربندی دوم در باس CAN FD نیز در شکل ۴-۵ قابل مشاهده میباشد. در این آزمون، نخست تلاش شد که باس با سرعتهای بیشتر از Mbps مورد آزمایش قرار بگیرد. ولی فرستنده-گیرنده در دسترس توانایی تفسیر سیگنالهای دریافتی در این نرخها را نداشت. به همین عالت، تلاش شد که از طریق آزمون و خطا، حداکثر نرخ بیتی قابل استفاده در فرستنده-گیرنده یافت شده و بررسی انجام شده در آن نرخ انجام شود. بنابراین، نرخ بیتی Mbps انتخاب شده و ارسال و دریافت بستهها با این نرخ انجام گرفت. نتایج قابل مشاهده در شکل ۴-۵ نشان میدهند که باس CAN

FD در محیط بدون نویز تا حدودی بهتر از CAN استاندارد عمل میکند، هر چند که اندکی افزایش تاخیر پس از ۱۰۰۰۰ بسته احتمالا به دلیل بیشتر بودن سربار CAN FD نسبت به CAN استاندارد است.



شکل ۴-۵: تاخیر باس ارتباطی بر حسب ترافیک شبکه در هر دو پیکربندی.

در گام بعدی، آزمون انجام شده را در محیطی با نویز کنترل شده تکرار میکنیم. به همین منظور، در مجاورت دو خط انتقال باس CAN، چندین دیود نوری به صورت پیاپی قرار گرفته است که هریک با فرکانسی بین فرکانس باس و فرکانس برد FPGA به صورت نوسانی روشن و خاموش میشوند. تعدادی از این دیودها مستقیما روی خطوط باس قرار گرفته و از این طریق روشن و یا خاموش میشوند و سایر دیودها از طریق یک برنامه خارجی کنترل شده و به صورت نوسانی روشن و یا خاموش میشوند. همچنین به صورت مداوم محدوده خطوط باس تحت تاثیر فرکانس رادیویی تلفن همراه قرار گرفته است که به طور مداوم در حالت مکالمه قرار داشته و در حال ارسال و دریافت همزمان داده میباشد. شکل ۴-۶ وضعیت این محیط را برای پیکربندی دوم نشان میدهد.

نتایج حاصل شده از ارزیابی در محیط نویزدار، مقاومت باس CAN FD و CAN FD را به خوبی نمایش می دهد. در تکرار مجدد آزمونهای مرحله قبل در محیط نویزدار، تنها در نرخ داده ۱۲۵ Kbps تعدادی خطا ایجاد شده و برای انتقال با سایر نرخها روی باس CAN و همچنین نرخ Mbps روی باس خطا ایجاد شده و برای انتقال با سایر نرخها روی باس CAN بسته که در مجموع انتقال ۱۰۰۰۰ بسته با نرخ CAN FD، هیچ خطایی ایجاد نشده و انتقال مانند قبل انجام شد. البته که در مجموع انتقال دست بسته با نرخ Kbps روی باس CAN، تنها ۹ بسته ۶۴ بیتی بر اثر نویزهای موجود در شبکه از دست رفته و به درستی به مقصد نرسیدند. این مساله حاکی از مقاومت بسیار مناسب لایه فیزیکی باس CAN در مقابل نویزهای محیطی است. این موضوع، معماری ارتباطی پیادهسازی شده را برای استفاده در محیطهای صنعتی و همچین خشن ۱۰ تبدیل گزینهای ایده آل می کند.



شکل ۴-۶: ارزیابی با نویز محیطی (پیکربندی دوم).

<sup>&</sup>lt;sup>1</sup> Harsh Environment

فصل پنجم نتیجهگیری و پیشنهادات

## نتیجه گیری و پیشنهادات

اهمیت ارتباطات و مخابرات در دنیای کامپیوتر و الکترونیک بر هیچ کس پوشیده نیست. این ارتباطات ممکن است در سطوح بالا و میان خوشههای کامپیوتری<sup>۱</sup> باشند، و یا در سطوح پایین و به منظور ارتباط اجزاء سیستمهای نفهته طراحی شوند. تلاشهای فراوانی در جهت ارائه استانداردهای مخابراتی در مبحث سیستمهای نهفته شده است که هر یک تلاشی برای محقق کردند اهدافی نظیر امنیت، اطمینان پذیری، سرعت تبادل اطلاعات و یا دیگر عاملها داشتهاند. در میان این استانداردها، هدف برخی صرف ارتباط در لایه فیزیکی بوده در حالی که برخی دیگر پروتکلهای سطح بالا هستند و در نهایت نیز تعدادی از این استانداردها یک پشته پروتکل کامل را شرح میدهند. این تلاشها باعث ارائه باسها پرکاربردی نظیر CAN و CAN شدهاست.

باس CAN نخستین بار در راستای ایجاد استاندارد در صنایع خودروسازی طراحی شده است ولی ویژگیها و تواناییهای آن، این باس را تبدیل به یکی از محبوب ترین باسهای ارتباطی در صنایع هوافضا، اتوماسیون و بسیاری از سیستمهای نهفته کردهاست[۲]. ویرایشهای متعددی از این باس در طول سالیان متوالی طراحی شده است که در این میان می توان به CAN FD اشاره نمود. هدف از توسعه استاندارد CAN FD، افزایش نرخ انتقال باس در کنار افزایش اطمینان پذیری البته بدون تغییر لایه فیزیکی CAN FD می باشد. با این وجود، باس CAN FD به علت نوین بودن کمتر مورد توجه کاربران و توسعه دهندگان قرار گرفته است. پیاده سازی یک ارتباط دو طرفه، با قرار گیری FPGA در یک سمت و میکروکنترلر در سمت دیگر به گونهای که باس ارتباطی از نوع CAN FD باشد، هدف نهایی این پروژه می باشد. همچنین صحت ارتباط ایجاد شده بررسی شده و کیفیت ارتباط مورد ارزیابی قرار گرفته است.

<sup>&</sup>lt;sup>1</sup> Cluster

طبق این توضیحات، راهاندازی این پروژه نیازمند دو پیادهسازی میباشد؛ یک پیادهسازی برای میباشد؛ یک پیادهسازی برای میکروکنترلر انجام شده و دیگری برای FPGA میباشد. علاوه بر این پیادهسازی، انتقال داده مبتنی برا پروتکل لایه بالا CANOpen نیز جزء اهداف این پروژه بوده است. متاسفانه به دلیل عدم دسترسی به کنترل کننده باس CAN FD، پیادهسازی این باس روی میکروکنترلر صورت نگرفته است و در طرح نهایی پیادهسازی شده، یک ارتباط میان میکروکنترلر و FPGA از طریق باس CAN استاندارد محقق شده است و در عوض، در قلب FPGA دو باس CAN FD قرار گرفتهاند که اطلاعات ارسالی از کنترل کننده CAN موجود روی FPGA را دریافت کرده و به صورت حلقه بازگشتی به یکدیگر ارسال نمایند. پیکربندی دیگری نیز پیادهسازی شده است که تنها روی FPGA راهاندازی شده است و بدین صورت میباشد که دو کنترل کننده CAN FD روی FPGA قرار گرفته و از طریق پایههای برد FPGA بیا یکدیگر ارتباط برقرار کرده و به تبادل داده می پردازند.

ارزیابی نهایی طرح روی FPGA و البته میکروکنترلر، نشاندهنده بهینگی باس CAN و همچنین CAN FD از نظر منابع سختافزاری مصرفی است. وجود چنین ویژگیای در کنار خواصی مانند نرخ داده بالا، سادگی و هزینه پایین باسهای CAN FD و CAN FD در کنار مقاومت بالا در مقابل نویز که در این پروژه مورد ارزیابی قرار گرفت، آنها را تبدیل به یک گزینه ایدهآل برای بسیاری از کاربردهای نهفته و به خصوص محیطهای خشن میکند.

باس CAN FD و مفاهیم مرتبط با آن، می توانند محل بسیاری از تحقیقات آینده باشند. شاخصهای متعددی که در طول سالیان به روی باس CAN مورد آزمایش قرار گرفته اند، مانند میزان توانایی و عملکرد آن در کاربردهای بلادرنگ  $[^{5}]$ ، همچنان برای باس CAN FD در هاله ای از ابهام قرار دارند. همچنین علاوه بر ویژگیهای مرتبط با سرعت و بهرهوری CAN FD، عواملی نظیر امنیت نیز مورد توجه زیاد قرار نگرفته اند، عاملی که در سالهای اخیر بسیار اهمیت یافته است  $[^{5}]$ .

همچنین همانطور که باس CAN FD اولین ویرایش باس CAN نبوده است، آخرین ویرایش نیز نخواهد بود. هم اکنون نیز تلاشهای متعددی برای توسعه ویرایشهای جدیدتر باس CAN در حال

انجام است که در این میان میتوان به دو مورد CAN XL و CAN TD Light اشاره نمود که استاندارد آنها در دست توسعه بوده و در سالهای آتی عرضه خواهند شد. CAN XL قابلیت ارسال محمولههایی تا ۲۰۴۸ بایت را خواهد داشت و ویژگیهای متعددی از مدل مرجع OSI به آن افزوده خواهد شد. همچنین تلاش کارگروه توسعه CAN XL بر آن که لایه فیزیکی جدیدی را برای این باس توسعه دهند که از نرخ ارسال پیشفرض Mbps به شتیبانی کند. همچنین CAN FD Light ویرایشی از CAN FD است که معماری ارتباطی آن به صورت پیرو/راهبر بوده و در عوض نرخ ارسال داده آن محدود به مقدار Mbps ۱ میباشد [۰۰].

بررسی و تحلیل عمیق تر باس CAN FD در کنار استانداردهای آینده این مسیر یعنی CAN XL و CAN FD در کنار استانداردهای آینده این مسیر یعنی CAN FD Light می تواند نتایج فوق العاده ارزشمندی را به همراه داشته باشد.

# منابع و مراجع

- [1] C. S. Clifton, What every engineer should know about data communications. pp. 1-7, 1987. Available: https://www.taylorfrancis.com/books/9781003065586
- [7] CAN in Auromation, "History of CAN technology." CAN in Auromation, 2019. Available: https://www.can-cia.org/can-knowledge/can/can-history/
- [7] A. Scholz, T.-H. Hsiao, J.-N. Juang, and C. Cherciu, "Open source implementation of ECSS CAN bus protocol for CubeSats," *Adv. Space Res.*, vol. 62, no. 12, pp. 3438–3448, Dec. 2018, doi: 10.1016/j.asr.2017.10.015
- [\*] International Organization for Standardization, "ISO 11898-1:2015," 2015. Available: https://www.iso.org/cms/render/live/en/sites/isoorg/contents/data/standard/06/36/63648.html
- [Δ] F. Hartwich, *CAN with flexible data-rate*, pp 3-11, 2012. Available: https://www.can-cia.org/fileadmin/resources/documents/proceedings/2012\_hartwich.pdf
- [\*] A. Mutter and Florian Hartwich, "Advantages of CAN FD Error detection mechanisms compared to Classical CAN," *CAN Autom. ICC*, 2015. Available: https://s3.eu-central-1.amazonaws.com/cancia-de/documents/proceedings/icc\_2015\_mutter.pdf
- [V] S. Corrigan, "Introduction to the Controller Area Network (CAN)," pp, 2-16. Available: https://www.ti.com/lit/an/sloa101b/sloa101b.pdf?ts=1643829417705&ref\_url= https%253A%252F%252Fwww.google.com%252F
- [^] CAN in Automation, "CAN in Automation (CiA): CANopen." Available: https://www.can-cia.org/canopen/.
- [9] S. Corrigan and S. Corrigan, "Introduction to the controller area network (CAN)," *Tex. Instuments*, 2002.
- ['\']Robert Bosch GmbH, "CAN Specification," pp. 1, 4-18, 23-30, 1991. Available: http://esd.cs.ucr.edu/webres/can20.pdf
- [11] USB Implementers Forum, "USB 2.0 Specification." pp, 139-140. Available: https://www.usb.org/document-library/usb-20-specification

- [\mathbb{\gamma}] Kvaser, "CAN Physical Layers," Dec. 2018. Available: https://www.kvaser.com/lesson/can-physical-layers/
- [16] CAN in Automation, "CAN Data Link Layer." pp. 1-26. Available: http://www.diakom.com.ru/el/communication/can/candll.pdf
- [14] NXP, "CAN Bit Timing Requirements," pp 1-3, 2004. Available: https://www.renesas.com/us/en/document/whp/isolated-can-bus-small-satellites?language=en
- [\forall f] Renesas, "Isolated CAN Bus for Small Satellite Applications," pp 1, Feb. 2019. Available: https://www.nxp.com/docs/en/user-guide/UM10204.pdf
- [\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\fir}{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\fir}{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\fir}}}}}}{\frac{\frac{\frac{\frac{\frac{\frac{\frac{\frac{
- [\frac{\lambda}{\rmath}] Texas Instruments, "Universal Synchronous Asynchronous Receive/Transmit USART," pp. 12\_1-12\_24. Available: https://www.ti.com/sc/docs/products/micro/msp430/userguid/ag\_12.pdf
- [19] Texas Instruments, "Serial Peripheral Interface User Guide," pp. 1\_2-1\_3, Mar. 2012. Available: https://www.ti.com/lit/ug/sprugp2a/sprugp2a.pdf
- [7 ·] FRANZIS, "MOST: THE AUTOMOTIVE MULTIMEDIA NETWORK," pp. 22-49, 2008. Available: http://www2.ciando.com/img/books/extract/3645250611\_lp.pdf
- [Y] AUTOSAR, "Specification of LIN Interface." pp. 9-14. Available: https://www.autosar.org/fileadmin/user\_upload/standards/classic/4-3/AUTOSAR\_SWS\_LINInterface.pdf
- [YY] FlexRay Consortium, "FlexRay Communications System Protocol Specification," pp. 14-31, Oct. 2010. Available: https://svn.ipd.kit.edu/nlrp/public/FlexRay/FlexRay%E2%84%A2%20Protocol%20Specification%20Version%203.0.1.pdf
- [YT] RF Wireless World, "LIN, CAN, FlexRay, MOST-Difference." Available: https://www.rfwireless-world.com/Terminology/LIN-vs-CAN-vs-FlexRay-vs-MOST.html
- [<sup>Y</sup>\*] L.-B. Fredriksson, "TTCAN explained," pp. 1-4, 2008 Available: https://www.kvaser.com/wp-content/uploads/2014/08/ttcan-explained.pdf.
- [Y\Delta] Microchip, "Controller Area Network with Flexible Data-rate (CAN FD)," pp. 56\_2-56\_8,2018. Available: https://www.can-cia.org/fileadmin/resources/documents/proceedings/2012\_hartwich.pdf

- [<sup>Y</sup><sup>7</sup>] G. Marcon Zago and E. Pignaton de Freitas, "A Quantitative Performance Study on CAN and CAN FD Vehicular Networks," *IEEE Trans. Ind. Electron.*, vol. 65, no. 5, pp. 4413–4422, May 2018, doi: 10.1109/TIE.2017.2762638.
- [YV] CAN in Automation, "CAN in Automation (CiA): CAN FD The basic idea." Available: https://www.can-cia.org/can-knowledge/can/can-fd/
- [YA] Robert Bosch GmbH, "CAN with Flexible Data-Rate," pp. 3-34, Apr. 2012. Available: https://can-newsletter.org/assets/files/ttmedia/raw/e5740b7b5781b8960f55efcc2b93edf8.p
- [<sup>Y q</sup>] Esatinc, "OBD II Specifications and Connections." Available: http://www.esatinc.ca/News\_Letters/OBD\_II\_Specifications\_and\_Connection s.pdf
- [\*\*] MicroControl, "J1939 Protocol Stack," pp. 9-11. Available: http://www.microcontrol.net/wp-content/uploads/2021/10/hb\_j1939\_v3r00\_en.pdf
- [<sup>r</sup>] CAN in Automation, "CAN in Automation (CiA): CANopen." CAN in Automation: https://www.can-cia.org/canopen/
- [<sup>YY</sup>] CAN in Automation (CiA), "CANOpen Report," 2016. Available: http://affon.narod.ru/CAN/CANopen.pdf
- [""] CAN in Automation (CiA), "CANopen application layer and communication profile." CAN in Automation (CiA), Feb. 2011. Available: https://www.cancia.org/index.php?eID=tx\_nawsecuredl&u=25087&g=11&t=1630974428&ha sh=05e0474253578c1227a3c60c3cfeb8429588578a&file=fileadmin/resources/documents/groups/301v04020007\_cor.pdf
- [<sup>\*\*</sup>] Siemens, "On-Board Communication via CAN without Transceiver." Available: https://www.mikrocontroller.net/attachment/28831/siemens\_AP2921.pdf
- [ Farnell, "Arduino Due." Available: http://www.farnell.com/datasheets/1682211.pdf
- [\(^{\gamma}\)] "Arduino Due," \(Arduino\) \(Online\) \(Shop\). \(http://storeusa.arduino.cc/products/arduino-due.\)
- [\*\*V] Xilinx, "Spartan-3 FPGA Family: Introduction and Ordering Information," pp. 1-16, Jun. 2013. Available: https://www.xilinx.com/support/documentation/data\_sheets/ds099.pdf
- [۳۸] هپویان علم و صنعت آوا، «برد توسعه Spartan3 AVA3S400»، قابل دسترسی از طریق پیوند: http://revsa.ir/products/xilinx-boards-and-kits/spartan3-ava3s400

- [<sup>rq</sup>]NXP, "TJA1050 High Speed CAN Transceiver Datasheet," pp. 1-18, Oct. 2003. Available: https://www.nxp.com/docs/en/data-sheet/TJA1050.pdf
- [\*•] M. Fezari and A. Al Dahoud, "Integrated Development Environment 'IDE' For Arduino," Oct. 2018. Available: https://www.researchgate.net/publication/328615543\_Integrated\_Development \_Environment\_IDE\_For\_Arduino
- [\*\]Xilinx, *ISE In-Depth Tutorial*, pp. 7-64 Oct. 2011. Available: https://www.xilinx.com/support/documentation/sw\_manuals/xilinx13\_3/ise\_tu torial\_ug695.pdf.
- [<sup>§</sup>] Xilinx, "Vivado Design Suite User Guide," pp. 5-9, Oct. 2017. Available: https://www.xilinx.com/support/documentation/sw\_manuals/xilinx2021\_1/ug9 04-vivado-implementation.pdf
- [<sup>\varphi\varphi</sup>] C. Kidder, *due\_can*. 2021. Available: https://github.com/collin80/due\_can
- [<sup>\*\*</sup>] X.Wang, FPGA-liteCAN. 2022. Available: https://github.com/WangXuan95/liteCAN
- [\forallow] Czech Technical University, CTU CAN FD IP Core. Available: https://gitlab.fel.cvut.cz/canbus/ctucanfd\_ip\_core
- [\$\dagger^{\gamma}] Czech Technical University, "CTU CAN FD IP Core Datasheet," pp. 2-69, Dec. 2021. Available: https://canbus.pages.fel.cvut.cz/ctucanfd\_ip\_core/doc/Datasheet.pdf
- [\*V] A. Mutter, R. Bosch, and F. Hartwich, "Advantages of CAN FD Error detection mechanisms compared to Classical CAN," 2015. Available: https://www.semanticscholar.org/paper/Advantages-of-CAN-FD-Error-detection-mechanisms-to-Mutter-Bosch/745ad99d9619f3e682edd97d25585a34a203b803
- [<sup>\(\psi\)</sup>] J. Xia, C. Zhang, R. Bai, and L. Xue, "Real-time and reliability analysis of time-triggered CAN-bus," *Chin. J. Aeronaut.*, vol. 26, no. 1, pp. 171–178, Feb. 2013, doi: 10.1016/j.cja.2012.12.017.
- [<sup>§ 9</sup>] A. Taylor, N. Japkowicz, and S. Leblanc, "Frequency-based anomaly detection for the automotive CAN bus," in 2015 World Congress on Industrial Control Systems Security (WCICSS), Dec. 2015, pp. 45–49. doi: 10.1109/WCICSS.2015.7420322.
- [5.] CAN in Automation, "CAN XL and CAN FD light." https://www.cancia.org/news/cia-in-action/view/can-xl-and-can-fd-light/

## پيوستها

در ادامه، کد پیادهسازی این پروژه برای میکروکنترلر و FPGA برای هر دو پیکربندی طراحی شده ارائه شده است.

#### FPGA جدول پ-۱: شرح کد پیادهسازی پیکربندی اول در

```
`timescale 1ns / 1ps
// Organization:
                      Amirkabir University of Technology
// Author: Mohamad
                      Chamanmotlagh
این بخش از کد، به توصیف ماژول اصلی و درگاههای متصل به آن میپردازد.
module top (
     clk,
     CAN RX,
     CAN TX,
     sending,
     received,
     data
);
     این بخش از کد، نوع هر یک از درگاههای ورودی و خروجی را مشخص مینماید. این درگاهها شامل کلاک سیستمی، سیگنالهای
                 RX و TX باس CAN، سیگنال نشانگر ارسال و دریافت و سیگنال نمایشگر داده خروجی می باشد.
                 wire clk;
                                      // System Clock
     input
                wire CAN_RX;
                                       // CAN Receive signla
     input
                wire CAN TX;
                                      // CAN Transmit signal
     output
                wire sending;
                                      // Send indicator
     output
                wire received;
                                       // Receive indicator
     output
                                       // Received data visualization
                wire [7:0]data;
     output
     _____//
این بخش، تعدادی از سیگنالهای میانی را توصیف می کند & سیگنالهای نظیر بازنشانی داخلی، داده ارسالی و دریافتی از ورودی−
                                   خروجی، و همچنین مقدار سیگنال کلاک Prescale شده.
     wire rstn;
                                  // Reset line
           [31:0] can tx cnt;
                                  // Sample sent data
     reg
                                  // Sent data is valid or not
         can tx valid;
          [31:0] can tx data;
                                  // Sent data
     rea
                                  // Received data is valid or not
     wire can rx valid;
     wire [7:0] can rx data;
                                  // Recived data
     wire clock out;
                                  // output clock after dividing the
                                  // input clock by divisor
                     دو مقدار دهی سیگنال انجام شده زیر، مقادیر نشانگر ارسال و دریافت را مشخص میکنند.
```

```
assign sending = can tx valid;
      assign received = can rx valid;
      //
این بخش، به تولید سیگنال بازنشانی باس CAN به صورت متناوب می پردازد. وجود این بخش ضروری نیست و می توان بازنشانی را
                                                 به یکی از پایههای ورودی FPGA متصل نمود.
      reset gen #(
            .DEFAULT(1),
            .tP(25000),
            .tR(25000)
      ) reset gen i(
            .rstn(1'b1),
            .clk(clk),
            .on(1'b0),
            .off(1'b0),
            .o rst(rstn)
      );
//
      این بخش، عامل Prescaler را بر روی کلاک سیستمی اعمال کرده و مقدار خروجی را درون سیگنال Clock_out قرار
                                   می دهد. در حالت فعلی، مقدار عامل Prescaler برابر ۴۰ می باشد.
      clock divider
      #(28'd40)
      clk_div(
            clk,
            clock out
            );
//
      وظیفه ی این بخش، تولید داده افزایشی به منظور ارسال روی خطوط باس و همچنین ارسال متناوب داده تولید شده می باشد.
      always @(posedge clock out or negedge rstn)
            if (~rstn) begin
                   can tx cnt <= 0;
                   can tx valid <= 1'b0;</pre>
                   can_tx_data <= 0;</pre>
            end
            else if (can tx cnt < 1000000) begin
                   can tx cnt <= can tx cnt + 1;
                   can tx valid <= 1'b0;</pre>
            end
            else begin
                   can_tx cnt <= 0;</pre>
                   can tx valid <= 1'b1;</pre>
                  can_tx_data <= can_tx_data + 1;</pre>
            end
      =========Instantiate CAN module==========//
در این بلوک از کد، یک نمونه از روی هسته LiteCAN ساخته می شود. در راستای همین امر، نخست متغیرهای پیکربندی (نظیر
تعداد کوانتوم زمانی بخشهای مختلف) مشخص شده و سپس سیگنالهای کنترلی و همچنین ورودی-خروجی این باس مقداردهی
```

```
can top #(
             .LOCAL ID(11'h456),
             .default c PTS(16'd2),
             .default c PBS1(16'd1),
            .default c PBS2(16'd2)
      ) can controller(
             .rstn(rstn),
             .clk(clock out),
             .can_rx(CAN RX),
             .can tx(CAN TX),
             .tx valid(can tx valid),
             .tx ready(),
             .tx data(can tx data),
             .rx_valid(can_rx_valid),
             .rx_last(),
             .rx_data(can_rx_data),
            .rx id(),
             .rx ide()
      );
//
      در این بخش، دو نمونه از کنترلکننده CAN FD ساخته شده و ارتباط میان آنها برقرار می شود. در گام نخست، سیگنالهای
                                 میانی دو کنترل کننده ساخته می شود؛ سپس نمونه هسته ها ساخته می شود.
                   CAN FD TX;
                                      // CAN-FD module Transmit signal
      req
                                      // CAN-FD module Receive signal
      req
                   CAN FD RX;
      wire
                   [31:0] extended date; // Extended data for CAN-FD
                   [31:0] read data;
                                             // CAN-FD module Returned data
                   extended data = {24'b0, can rx data};
      assign
در این مرحله، دو هسته CTU CAN FD نمونه سازی می شوند. این هسته از طریق سیگنال های TX و RX باس CAN FD با
یکدیگر ارتباط دارند. ارتباط خارجی آنها با سایر ماژولهای کد نیز از طریق واسط AMBA APB طراحی شده درون هستهها
                                                                    صورت مي گيرد.
      can_fd_top_apb FDCAN T(
             .CAN_tx(CAN_FD_TX),
             .CAN_rx(CAN_FD_RX),
             .aclk(clock_out),
             .arstn(rstn),
             .s_apb_pwdata(extended_date),
             .s apb pwrite(can rx valid),
             .s apb psel(can rx valid),
             .scan enable(),
             .res n out(),
             .irq(),
             .timestamp(),
             .s apb paddr(),
             .s_{apb_penable(1'b1)},
             .s apb_pprot(),
             .s apb pready(),
             .s apb pslverr(),
             .s apb pstrb(),
             .s apb prdata()
```

```
);
            can fd top apb FDCAN R(
            .CAN tx(CAN FD RX),
            .CAN rx(CAN FD TX),
            .aclk(clock out),
            .arstn(rstn),
            .s apb pwdata(),
            .s_apb_pwrite(),
            .s_apb_psel(can_rx_valid),
            .scan enable(),
            .res_n_out(),
            .irq(),
            .timestamp(),
            .s_apb_paddr(),
            .s_apb_penable(1'b1),
            .s_apb_pprot(),
            .s apb pready(),
            .s apb pslverr(),
            .s apb pstrb(),
            .s apb prdata(read data)
            );
//
      در گام آخر، داده دریافت شده از کنترل کننده CAN FD دوم روی سیگنال خروجی نمایشدهنده داده FPGA نوشته می شود.
      assign data = read data[7:0];
endmodule
                                                          انتهای ماژول بالاترین سطح.
//
      ========Clock divider module========//
                    این ماژول، وظیفه تغییر طول کلاک و در حقیقت اعمال عامل Prescaler را بر عهده دارد.
LIBRARY IEEE;
USE IEEE.STD LOGIC 1164.ALL;
USE IEEE.numeric_std.ALL;
                                            در ابتدا، نام ماژول و درگاههای آن توصیف میشوند.
ENTITY Clock Divider IS
       GENERIC (Prescaler : INTEGER);
        PORT (
                clk,
               clock out : OUT std logic
        );
END Clock Divider;
ARCHITECTURE bhv OF Clock_Divider IS
        SIGNAL count : INTEGER := 1;
        SIGNAL tmp : std_logic := '0';
```

```
and Description and Descripti
```

#### FPGA جدول پ-۲: شرح کد پیادهسازی پیکربندی دوم در

```
`timescale 1ns / 1ps
// Organization:
                    Amirkabir University of Technology
// Author: Mohamad
                     Chamanmotlagh
این بخش از کد، به توصیف ماژول اصلی و درگاههای متصل به آن میپردازد.
module top_config_2(
   input RX_1,
   output TX_1,
   input RX_2,
   output TX 2,
   input CLK,
   output sending,
   output receiving,
   output [7:0] data
   );
     ========Apply Prescaler for CAN==========//
  در این بخش، عامل Prescaler روی کلاک سیستمی اعمال شده و سیگنال خروجی درون clock_out قرار می گیرد.
                                     // output clock after dividing
     wire clock out;
the input clock by divisor
     clock divider
     \#(28'd1)
                                           // Prescale factor
     clk_div(
          clk,
          clock out
          );
                 ====Send Preiodic Data=========//
  در این بخش، دادهی ارسالی روی باس CAN FD تولید شده و به صورت متناوب تغییر کرده و درخواست ارسال صادر می شود.
     rea
                send:
                [31:0] counter;
     reg
```

```
[31:0] sent data = 32'b0;
       always @(posedge clock out)
              if (counter < 1000000) begin
                    counter <= counter + 1;</pre>
                    send <= 1'b0;
             end
             else begin
                    counter <= 0;
                    send <= 1'b1;
                    sent data <= sent data + 1;</pre>
             end
                   sending = send;
       assign
//
       =========Instantiate CAN-FD modules==========//
در این بخش، دو عدد ماژول CAN FD نمونهسازی شده و درگاههای آن از طریق سیگنالهای مربوطه مقداردهی میشوند.
  همچنین داده تولید شده در بلوک قبل، از طریق ماژول CAN FD اول ارسال شده و در ماژول CAN FD دوم دریافت می شود.
                    [31:0] read data;
                                                     // CAN-FD module 1
      wire
Returned data
       can_fd_top_apb FDCAN_1(
              .CAN_tx(TX_1),
              .CAN_{rx}(RX_1),
              .aclk(clock out),
              .arstn(1'b1),
              .s apb pwdata(sent data),
              .s_apb_pwrite(send),
              .s_apb_psel(1'b1),
              .scan_enable(),
              .res_n_out(),
              .irq(),
              .timestamp(),
              .s apb paddr(),
              .s apb penable(1'b1),
              .s_apb_pprot(),
              .s_apb_pready(),
              .s_apb_pslverr(),
              .s_apb_pstrb(),
              .s_apb_prdata()
             can_fd_top_apb FDCAN_2(
  .CAN_tx(TX_2),
  .CAN_rx(RX_2),
              .aclk(clock out),
              .arstn(1'b1),
              .s apb pwdata(),
              .s apb pwrite(),
              .s_apb_psel(1'b1),
              .scan_enable(),
              .res_n_out(),
              .irq(),
              .timestamp(),
             .s apb paddr(),
```

#### به جدول پ- $^{\circ}$ : فایل ایجاد محدودیت برای مسیریابی ورودی و خروجیهای FPGA.

```
# Geberal ports
                                         این بخش از فایل محدودیت، در هر دو پیکربندی یکسان است.
NET "clk" LOC = P184;
NET "sending" LOC = P42;
NET "received" LOC = P44;
NET "data[7]" LOC = P61;
NET "data[6]" LOC = P62;
NET "data[5]" LOC = P63;
NET "data[4]" LOC = P64;
NET "data[3]" LOC = P65;
NET "data[2]" LOC = P67;
NET "data[1]" LOC = P68;
NET "data[0]" LOC = P71;
# Configuration 1 ports
                                         این بخش از فایل محدودیت، مخصوص پیکربندی اول میباشد.
NET "CAN TX" LOC = P189;
NET "CAN RX" LOC = P190;
# Configuration 2 ports
                                         این بخش از فایل محدودیت، مخصوص پیکربندی دوم میباشد.
NET "TX 1" LOC = P189;
NET "RX 1" LOC = P190;
NET "TX 2" LOC = P194;
NET "RX 2" LOC = P191;
```

#### جدول پ- $^{+}$ : شرح کد پیادهسازی پیکربندی اول در میکروکنترلر.

```
/**

* Author: Mohamad Chamanmotlagh

* Organization: Amirkabir University of Technology

*/

این بخش از کد وظیفه ارسال و دریافت پیام باس CAN را بر عهده دارد.

// Required libraries
```

```
#include "variant.h"
#include <due can.h>
                                    در این بخش، متغیرهای جهانی ۱ مورد نیاز تعریف و مقدار دهی میشوند.
//random ID
#define TEST1 CAN TRANSFER ID
                                   0x456
// CAN frame max data length
#define MAX CAN FRAME DATA LEN
// Number of test frames
#define TEST MAX COUNT 10000
// CAN's bit rate
#define BIT RATE 125000
                                      این متغیرها مسئول شمارش تعداد پیامهای ارسالی و دریافتی هستند.
Uint32 t sentFrames, receivedFrames;
//Leave this defined if you use the native port or comment it out if you
use the programming port
//#define Serial SerialUSB
// Used frames
CAN FRAME frame, incoming;
void setup() {
// start serial port at 115200 bps:
 Serial.begin(115200);
// Wait unitl serial monitor is opened
 while(!Serial);
   در این بخش، کنترل کننده CAN مقدار دهی اولیه شده و آماده ارسال و دریافت با نرخبیتی متغیر BIT_RATE میشود.
  // Verify CANO initialization with BIT RATE:
  if (Can0.begin(BIT RATE)
    ("با موفقیت راهاندازی شد. : Serial.println("CANO);
  else
    Serial.println("CAN initialization (sync) ERROR");
                                                  در این بخش، یک قاب پیام CAN ساخته می شود.
  //Initializing the sending frame.
  frame.id = TEST1 CAN TRANSFER ID;
 frame.length = MAX CAN FRAME DATA LEN;
  frame.data.value = 0;
  frame.extended = 1;
این قطعه کد، کنترلکننده CAN را به گونهای مقداردهی میکند که آماده دریافت پیامهایی با شناساگر
                                                     TEST1 CAN TRANSFER ID باشد.
  // Filter incoming IDs
```

<sup>&</sup>lt;sup>1</sup> Global variable

```
Can0.watchFor(TEST1 CAN TRANSFER ID);
                                                          تابع ارسال و دریافت پیام فراخوانی می شود.
  start_can();
        Sending and receiving pure CAN messages
                 این تابع، وظیفه ارسال قاب پیام ساخته شده و همچنین دریافت پیامهای دارای شناساگری خاص را دارد.
static void start can(void)
  uint32_t counter = 0;
  while (1==1) {
در یک حلقه نامتنهای، به صورت مداوم قاب ساخته شده روی باس ارسال میشود تا ترافیک مناسب را ایجاد کند. همچنین مقدار
                                                          محموله پیام در هر ارسال افزایش می یابد.
     // Send data on bus lines
    if(sentFrames < TEST MAX COUNT){</pre>
      Can0.sendFrame(frame);
       sentFrames++;
       frame.data.value += 2;
    Serial.print((int)frame.data.value);
    Serial.print("\t");
به صورت مداوم، بافر ورودی کنترلکننده CAN بررسی شده و در صورتی که پیامی روی آن موجود باشد، آن مقدار خوانده شده و
                                                                        قابل مشاهده میباشد.
    // Read incoming messages if any is available
    if (Can0.available() > 0) {
       Can0.read(incoming);
       Serial.print((int)incoming.data.value);
      Serial.print("\t");
      receivedFrames++;
      counter++;
     } else {
      Serial.print("-");
       Serial.print("\t");
     Serial.print(sentFrames);
     Serial.print("\t");
     Serial.print(receivedFrames);
     Serial.print("\t");
    در این بخش، ثبات خطای کنترل کننده CAN برای هر دو نوع پیام ارسالی و دریافتی خوانده شده و مقدار آن گزارش میشود.
    // Couting number of errors
    int total error 1 = Can0.get rx error cnt() +
Can0.get tx error cnt();
```

```
Serial.println(total error 1);
    // Finish if all of messages hasbeen recieved
    if(receivedFrames == sentFrames)
      break;
void loop()
        Initializing CAN controller
در این قطعه کد، کنترلکننده CAN مقداردهی اولیه میشود. این مقداردهی به معنای مشخص نمودن متغیرهای زمانی CAN
uint32 t CANRaw::set baudrate(uint32 t ul baudrate)
                                                     در این بخش، متغیرها مقداردهی اولیه میشوند.
       uint8 t uc tq;
      uint8 t uc prescale;
      uint32 t ul mod;
      uint32 t ul cur mod;
       can bit timing t *p bit time;
       static uint32 t ul mck = SystemCoreClock;
       در صورتی که مقدار prescaler بیشتر از حداکثر قابل استفاده باشد، عملیات با خطا مواجه شده و به اتمام میرسد.
       if (((ul mck + (ul baudrate * CAN MAX TQ NUM - 1)) /
              (ul baudrate * CAN MAX TQ NUM)) > CAN BAUDRATE MAX DIV) {
              return 0;
       }
                              اگر اندازه کلاک سیستمی کمتر از اندازه قابل قبول باشد، تابع با خطا مواجه می شود.
       if (ul mck < ul baudrate * CAN MIN TQ NUM) {
              return 0;
       }
                                          مقدار کوانتوم زمانی تقریبی با توجه به نرخ بیتی انتخاب می شود.
       uc_tq = CAN_MIN_TQ_NUM;
       ul_mod = 0xffffffff;
       for (uint8_t i = CAN_MIN_TQ_NUM; i <= CAN_MAX_TQ_NUM; i++) {
              if ((ul mck / (ul baudrate * i)) <= CAN BAUDRATE MAX DIV) {</pre>
                     ul cur mod = ul mck % (ul baudrate * i);
                     if (ul cur mod < ul mod) {
                           ul mod = ul cur mod;
                            uc tq = i;
                            if (!ul mod) {
                                  break;
                            }
```

```
uint32 t ul status = m pCan->CAN SR;
                                                      مقدار عامل Prescaler انتخاب می شود.
      uc prescale = ul mck / (ul baudrate * uc tq);
بر اساس مقادیر محاسبه شده تاکنون (کوانتوم زمانی و عامل Prescaler)، سایر مقادیر زمانی از داخل لیستی که از پیش
                                                             نوشته شده است انتخاب می شوند.
      p bit time = (can bit timing t *)&can bit time[uc tq -
CAN MIN TQ NUM];
      در این بخش، کنترل کننده باس CAN غیرفعال شده و سپس مقادیر زمانی روی ثباتهای آن نوشته می شوند. در پایان نیز
                                       کنترل کننده مجددا آغاز به کار کرده و عملکرد تابع به اتمام میرسد.
    can disable(m pCan);
    uint32 t oldCANMR = m pCan->CAN MR;
    m pCan->CAN MR &= ~CAN MR CANEN;
    m pCan->CAN BR = CAN BR PHASE2(p bit time->uc phase2 - 1) |
                                  CAN_BR_PHASE1(p_bit_time->uc_phase1 - 1) |
                                  CAN_BR_PROPAG(p_bit_time->uc_prog - 1) |
                                  CAN_BR_SJW(p_bit_time->uc_sjw - 1) |
                                  CAN BR BRP (uc prescale - 1);
    m pCan->CAN MR = oldCANMR;
    ul_status = m_pCan->CAN_SR;
    (void)ul status;
    numBusErrors = 0;
    numRxFrames = 0;
    busSpeed = ul baudrate;
    return 1;
}
/*
                                   * /
       CANOpen Functions
    در این قطعه کد، کنترل کننده، عملکردهای مربوط به ارسال و دریافت پیامهای مطابق پروتکل CANOpen انجام شده است.
                                     ساختار زیر، ویژگیهای یک گره شبکه CANOpen را مشخص میکند.
typedef struct {
                                      // Node-Id
                     node id;
    uint8 t
                                     // Baudrate
    uint32 t
                     Baudrate;
    struct CO_OBJ_T *Dict;
                                     // object dictionary
    uint16 t dict len;
                                    // object dictionary (max) length
} CO NODE;
                                            ساختار زیر، یک قاب پیام CANOpen را مشخص مینماید.
typedef struct {
    unit8 t node id;
                              // node id
    unit8_t function_code; // function of the message
                              // request for data
    unit8 t RTR;
    unit8 t length;
                              // length of the data
    unit8 t data;
                               // payload data
} CO FRAME;
عملکرد این تابع بدین صورت میباشد که یک پیام متنی در قالب یک رشته را دریافت نموده محتوای آن را به صورت پیامهای
```

```
CANOpen در آورده و بازگردانی می کند.
CO FRAME* send co frame(char* msg){
                                              در ابتدا، اندازه پیام و تعداد قطعات مورد نیاز محاسبه میشود.
    size_t msg_count = 0;
    while (msg[msg_count] != '\0') msg_count++;
    CO FRAME *messages = malloc(sizeof(CO FRAME) * msg count);
    int i = 0;
      در این قطعه از کد، پیام مورد نظر به قطعات کافی تقسیم شده و هر قطعه درون یک قاب پیام CANOpen قرار می گیرد.
    // Segmenting the whole message
    while (I <= msg count) {</pre>
         CO FRAME frame;
           // function-code for sending data messages is 0x3
         frame.function code = 0x3;
          // node-id is assumed 1 for the microcontroller
         frame.node id = 1;
         frame.RTR = 0;
         frame.length = msg count - i;
         frame.data = (int)msg;
         messages[i] = frame;
         i++;
                                  در پایان نیز اشارهگری به آرایه پیامهای CANOpen تولیدی بازگردانده میشود.
    return messages;
  در این بلوک از کد، پیامهای دریافی پیاپی مطابق پروتکل CANOpen دریافت شده و محموله نهایی تولید و بازگردانی میشود.
char * receive co frame(CO FRAME* messages){
                                        در ابتدای دریافت پیامهای CANOpen، تعداد پیامها محاسبه می شود.
    CO_FRAME frame_1 = messages[0];
    if(frame_1.function_code != 0x3)
         return NULL;
    size t len = messages[0].length;
    char * full_msg = malloc(sizeof(char) * len);
با در اختیار داشتن تعداد پیامها، در این بخش پیامهای متوالی خوانده شده و از طریق محموله هر یک، محموله کلی تولید میشود.
     for (int i = 0; i < len; i++) {
         char msg_char = messages[i].data +'0';
         full msg[i] = msg char;
                                                     در پایان نیز محموله کامل پیامها بازگردانی میشود.
    return full msg;
```

Name: CANSendSegment

File: CANALP.C

Inputs: CanID, CanData

Outputs: -

Global Variables: ActiveCAN

Peripherals: -

Explanation

این تابع سگمنت CANی که از وروی می گیرد را برای ارسال به CAnTxTask می فرستد. اگر صف CAn نعال باس CAN می شود، فلذا CAN سیگنال عوض کردن CAN فعال را مخابره می کند و ارسال سگمنت CAN را صورت می دهد.



Name: ProcessPacket

File: CANALP.C

Inputs: DesTask, CanPacket

Outputs: -

Global Variables: -

Peripherals: -

Explanation:

این تابع بسته دریافت شده از CAN را به Task مربوطه می<br/>فرستد.



Name: ProcessCANError

File: CANALP.C

Inputs: DesTask, CANOpenRegs

Outputs: -

Global Variables: CANOpenError, ProcessCAnError, TLMCanError, TLC

CanError, SBCanError

Peripherals: -

Explanation:

این تابع در زمان به مشکل خوردن پروتکل CANOpen فراخوانی می شود و شمارندههای Error را زیاد می کند.



### **Abstract**

Communication between computers and electronic components is a significant issue in engineering sciences. Numerous efforts have been made to offer and standardize these communications. Some of these proposed standards define merely the physical connection, while others define high-level protocols as well. These standards include, but are not limited to, SPI, I2C, and CAN busses. The CAN bus has established itself as a well-known standard bus in the automotive, automation, and aerospace industries, among others, and different variations of this bus have been produced to satisfy various requirements across industries. CAN FD is a customized version of the CAN bus that accelerates transmission without altering the physical layers of the CAN bus. Due to the novelty of CAN FD, little effort has been expended on its implementation and use. The ultimate goal of this project is to implement two-way communication based on both CAN and CAN FD busses using a microcontroller and an FPGA using CAN FD bus utilization. Therefore, in the implementation of this project, two types of implementations (microcontroller and FGA) were developed, and finally, upon successful communication, the data rate, accuracy, and reliability of the transfer were evaluated. Also, efforts have been made to use the CANOpen protocol as a high-level protocol.

**Keywords:** Communication Interface, Data Bus, Embedded System, Microcontroller



# Amirkabir University of Technology (Tehran Polytechnic)

**Department of Computer Engineering** 

**B.Sc.** Thesis

# Implementation of a data communication system between a microcontroller and an FPGA using CAN-FD bus interface and CANOpen Protocol

By Mohamad Chamanmotlagh

Supervisor **Dr. M. Mehdi Homayounpour** 

February 2022